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INTRODUCTION 

Microprocessor-based system designs are a cost- 
effective solution to a wide variety of problems. 
When a system designer is presented with the 
task of selecting a microprocessor for a design, the 
capabilities of the microprocessor should not be 
the only consideration. The microprocessor should 
be an element of a compatible family of devices. 
The MCS-80 component family is a group of com- 
patible devices which have been designed to 
directly address and solve the problems of micro- 
processor-based system design. One member of the 
MCS-80 component family is Intel's 8255 pro- 
grammable peripheral interface chip. This device 
replaces a significant percentage of the logic re- 
quired to support a variety of byte oriented Input/ 
Output interfaces. Through the use of the 8255, 
the I/O interface design task is significantly simpli- 
fied, the design flexibility is increased, and the 
number of components required is reduced. 

This application note presents detailed design 
examples from both the hardware and software 
points of view. Since the 8255 is an extremely 
flexible device, it is impossible to list all of the 
applications and configurations of the device. A 
number of designs are presented which may be 
modified to fulfill specific user interface require- 
ments. 

Detailed design examples are discussed within the 
context of the 8080 system shown in Figure 1. The 
basic 8080 system is composed of the CPU mod- 
ule, memory module, and the I/O module. CPU 
module and memory module design are discussed 



within other Intel publications. This appli:ation 
note deals exclusively with I/O module cesign. 

It is assumed that the reader is familiar wi:h the 
"8080 Microcomputer Systems User's Maiual", 
particularly the 8255 device description. 

OVERVIEW OF THE 8255 

The 8255 block diagram shown in Figure 2 has 
been divided into three sections: 8080 CPU Mod- 
ule Interface, Peripheral Interface, and the Internal 
Logic. 
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Figure 1. Typical 8080 System 



Figure 2. 8255 Block Diagram 



8080 CPU MODULE INTERFACE 

The 8255 is a compatible member of the MCS-80 
component family and, therefore, may be directly 
interfaced to the 8080. Figure 3 displays one 
method of interconnecting the 8255 and an 8080 
CPU module. The 8080 CPU module consisis of 
the 8080A CPU, the 8224 Clock Generator, and 
the 8228 System Controller. The system shown in 
Figure 3 utilizes a linear select scheme which dedi- 
cates an address line as an exclusive enable (chip 
select) for each specific I/O device. The chip select 
signal is used to enable communication between 
the selected 8255 and the 8080 CPU. I/O Pons A, 
B, C or the Control Word Register are selected by 
the two port select signals (A], An). These signals 
(Ai and An) are driven by the least significant bits 
of the address bus. The I/O port select characters 
required by this configuration are shown in Fig- 
ure 4. 
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When a system utilizing the linear select scheme is 
implemented, a maximum of six I/O devices may 
be se'ected. If more than six I/O devices must be 
addressed, the six device select bits must be en- 
coded to generate a maximum of 64 device select 
lines. Note that when large systems are imple- 
mented, bus loading considerations may require 
that bus drivers be included in the CPU module. 
The MCS-80 component family contains parts 
which are designed to perform this function (8216, 
8226). 

The 8255 I/O read (RD) and I/O write (WR) 
signals may be directly driven by the 8228. This 
results in an isolated I/O architecture where 8080 
Inpul /Output instructions are used to reference an 
independent I/O address space. An alternate ap- 
proach is memory mapped I/O. This architecture 
treat:; an area of memory as the I/O address space. 
The memory mapped I/O architecture utilizes 
8080 memory reference instructions to access the 
I/O address space. Interfacing with the 8080 is 
outlHed in Chapter 3 of the "8080 Microcomputer 
Users Manual". 

The most important feature of the 8255 to 8080 
CPU Module Interface is that for small system 
designs the 8255 may be interfaced directly to the 



standard MCS-80 component family with no 
external logic. Minimum external logic is required 
in large system designs. 
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Figure 4. I/O Port Select Characters 
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PERIPHERAL INTERFACE SECTION 

The peripheral interface section contains 24 per- 
ipheral interface lines, buffers, and control logic. 
The characteristics and functions of the interface 
lines are determined by the operating mode se- 
lected under program control. The flexibility of 
the 8255 is due to the fact that the device is pro- 
grammable. Three modes of operation may be 
selected under program control: Mode — Basic 
Input/Output, Mode 1 - Strobed Input/Output 
with interrupt support, and Mode 2 — Bidirectional 
bus with interrupt support. Through selecting the 
correct operating mode, the interface lines may be 
configured to fulfill specific interface require- 
ments. The characteristics of the interface lines 
within each mode must be understood so that the 
designer may utilize the 8255 to achieve the most 
efficient design. Table I lists the basic features of 
the peripheral interface lines within each mode 
group. Figure 5 shows the grouping of the periph- 
eral interface lines within each mode. 



Table I. Features of Peripheral Interface Lines 



Mode — Basic Input/Output 



Two 8-bit ports 

Two 4-bit ports with bit set/reset capability 
Outputs are latched 
Inputs are not latched 



Mode 1 - Strobed Input/Output 



One or two strobed ports 
Each Mode 1 port contains: 

8-bit data port 

3 control lines 

Interrupt support logic 
Any port may be input or output 
If one Mode 1 port is used, the remaining 13 lines 
may be configured in Mode 0. 

If two Mode 1 ports are used, the remaining 2 bits 
may be input or output with bit set/reset capability. 



Mode 2 - Strobed Bidirectional Bus 



One bidirectional bus which contains: 

8-bit bidirectional bus supported by Port A 
5 control lines 
Interrupt support logic 
Inputs and outputs are latched 

The remaining 11 lines may be configured in either 
Mode or Mode 1. 



One feature of Port C is important to note. Each 
Port C bit may be individually set and reset. 
Through the use of this feature, device strobes may 
be easily generated by software without uiilizing 
external logic. The Mode 1 and Mode 2 configura- 
tions use a number of the Port C lines for interrupt 
control lines. Thus, the 8255 contains a large por- 
tion of the logic required to implement an inter- 
rupt driven I/O interface. This feature simplifies 
interrupt driven hardware design and saves a signi- 
ficant amount of the external logic that is normally 
required when less powerful I/O chips are used. In 
fact, the design examples contained in this applica- 
tion note describe how interrupt driven interfaces 
may be designed such that the only interrupt con- 
trol logic required is that contained in the 8255. 
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INTERNAL LOGIC SECTION 

The irternal logic section manages the transfer of 
data and control information on the internal data 
bus (refer to Figure 2). If the port select lines (Ai 
and Aj) specify Ports A, B, or C, the operation is 
an I/O port data transfer. The internal logic will 
select the specified I/O port and perform the data 
transfer between the I/O port and the CPU inter- 
face. As was previously mentioned, both the func- 
tional configuration of each port and bit set/reset 
on Pert C are controlled by the system's software. 
When the control word register is selected, the 
interral logic performs the operation described by 
the control word. The control word contains an 
opcode field which defines which of the two func- 
tions are to be performed (mode definition or bit 
set/reset). 

Mode Definition 

When the opcode field (Bit 7) of the control word 
is equal to a one, the control word is interpreted 
by trie 8255 as a mode definition control word. 
The mode definition control word (shown in Fig- 
ure o) is used to specify the configuration of the 



24 8255 peripheral interface lines. The system's 
software may specify the modes of Port A and Port 
B independently. Port C may be treated independ- 
ently or divided into two portions as required by 
the Port A and Port B mode definitions. 

Example #1 : This example demonstrates how a 
mode control word is constructed and issued to an 
8255. The mode control word is passed to the 
device through the use of an output instruction 
that references an 8080 I/O port address. The value 
of the I/O port address is determined by the 8080 
CPU interface implemented. This example refer- 
ences the I/O port addresses realized by the simple 
8080 to 8255 interface shown in Figure 3. 

If an 8255 is to be configured through the use of 
the mode control word interface as: 

Port A Mode Input 

Port B Mode 1 Output 

Port C Bits PC7-PC4 Output 

Port C Bit 3 Input 

The following mode control word is used: 



CONTROL WORD 



E 



y GROUP B 


\ 


PORT C (LOWER - PC 3 - 


-PC I 


1 - INPUT 




= OUTPUT 




PORT B 




1 - INPUT 




= OUTPUT 




MODE SELECTION 




= MODE 




1 - MODE 1 





PORT C (UPPER - PC 7 -PC 4 I 
1 - INPUT 
= OUTPUT 



PORT A 
1 = INPUT 
= OUTPUT 

MODE SELECTION 

00 = MODE 

01 = MODE 1 
IX - MODE 2 



X 



1 = MODE SET 





°5 


D 4 


D 3 j D 2 j D, 


DO 



Port C Bit 3 Input ^ 1 



Port B Output - 



Port B Mode 1 - 1 



PortC Bits PC7-PC4 Output = 



Port A I nput = 1 



Port A Mode = 00 



Opcode Mode Set = 1 



Mode Control Word = 10010101 Binary 



The assembly language program is: 



EQU 0FBH 
ISSUE MODE CONTROL WORD 



MVI 
OUT 



A.I0010101B 
CWR 



;8255 #1 CONTROLWORD REGISTER 



; GET MODE CONTROL WORD 

; OUTPUT TO 825S #1 CONTROL WORD 

; REGISTER 



Figure 6. Mode Definition Control Word 
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Bit Set/Reset 

When the opcode field (Bit 7) of the control word 
is equal to a zero, the control word is interpreted 
by the 8255 as a Port C bit set/reset command 
word (see Figure 7). Through the use of the bit 
set /reset command, any of the 8 bits on Port C 
may be independently set or reset. Note that con- 
trol word bits 6—4 are not used. Bits 6—4 should 
be set to zero. 



Control word (see Figure 7). 



D 7 | D6 | D 5 | °4 | p 3 | °2 I Dl | Dp 




Set Bit = 1, Reset Bit = 



Bit Select - 011 (Binary) = 3 (Decimill 



Not Used = 000 (Binary) 



Bit Set/Reset Opcode = 



The control word for set Port C bit 3 is OO00O1 1 1 binary. 
The control word for reset Port C bit 3 is 000001 10 binary. 



The assembly language program is: 



CONTROL WORD 



O, D 6 | D 6 D 4 D 3 D 2 D i D„ 



NOT USED SET TO 000 



4- 



SET/RESET FLAG 



= RESET BIT 

1 = SET BIT 



D 3 


D 2 


D 1 


PORT C BIT 











BIT 








1 


BIT 1 





1 





BIT 2 





1 


1 


BIT 3 


1 








BIT 4 


1 





1 


BIT 5 


1 


1 





BIT 6 


1 


1 


1 


BIT 7 



- BIT SET/RESET 



EOU OFBH 
SET BIT 3 



MVI 
OUT 



A, 0000011 IE 



RESET BIT 3 



MVI 
OUT 



a, ooooonoB 

CWR 



8255 =1 CONTROL WORD REGISTER 



; GET SET BIT 3 CONTROL WORD 

; OUTPUT TO 8255 =1 CONTROL WORD REGISTER 



; GET RESET BIT 3 CONTROL WORD 

; OUTPUT TO 3255 =1 CONTROL WORD REGISTER 



NOTE: An MVI instruction is used to load the reset bit 3 
control word into the A register. Since it is known 
that the set bit control word is already in the A 
register, a "DCR A" Instruction could be ised to 
generate the correct control word and s;ve one 
byte of code. 

00000111 - 1 = 00000110 (RESET BIT 3 CON- 
TROL WORD) 



Example #3: This example demonstrates one 
simple method of performing a bit set/reset opera- 
tion on Ports A and B. The state of any output 
port may be determined by reading the port. The 
assembly language program which may be used to 
set/reset Port A or B bits is: 

Figure 7. Bit Set/Reset Control Word 



Example #2: This example demonstrates how a 
Port C bit set/reset control word is constructed and 
issued to an 8255. The bit set/reset control word is 
passed to the device through the use of an output 
instruction that references an 8080 I/O port ad- 
dress. The value of the I/O port address is deter- 
mined by the 8080 CPU interface implemented. 
This example references the I/O port addresses 
realized by the simple 8080 to 8255 interface 
shown in Figure 3. 



PORTA EOU 0F8H 
; SET BIT 



ORI 
OUT 



PORTA 
01 H 

PORTA 



RESET BIT 



AN I 
OUT 



PORTA 

0FEH 

PORTA 



; 8255 -1 PORT A 



; GET STATE OF PORT 

, SET BIT 

; OUTPUT TO PORT 



; GET STATE OF PORT 

, RESET BIT 

; OUTPUT TO PORT 
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INTERRUPT CONTROL LOGIC STATUS 
WORDS 

As previously mentioned, the 8255 Mode 1 and 
Mode 2 configurations support interrupt control 
logic. If a read of Port C is issued when the 8255 is 
configured in Mode 1 , the software will receive-the 
Mode I status word shown in Figure 8. The bits in 
the status word correspond to the state of the asso- 
ciated Port C lines (buffer full, interrupt request, 
etc.). The INTE bit shown in the status word corre- 
sponds to the interrupt enable flip-flop contained 
in the 8255. This signal is not available externally. 
The structure of the Mode 1 status word varies as a 
function of the mode of the 8255. Example #4 
shows the status word which results from reading 
Port C from an 8255 which is configured with Port 
A Mode 1 input and Port B Mode 1 output. 



D 7 D 6 D 5 D 4 D 3 j D; [ Pi "o^j 



Not Used => Set to 



Port B Output = 



Port B Mode 1 = 1 



Port C Bits 6 & 7 Output - 
Port A Input ^ 1 



Port A Mode = 01 



Opcode Mode Set = 1 



Mode Control Word - 101 10100 Binary. 



After the 8255 mode control word has been issued, 
a READ of Port C will obtain the following Mode 
1 status word: 
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STATUS 
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STATUS 
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D 1 
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INTE B 


IBF B 


INTRg 


OUTPUT 
PORT 






1 

i 




D 2 




D 


INTE B 


OBFrj 


INTRg 



Mode 1 Status Word 
from Port C READ 





°6 


°5 


D„ 


D 3 


D 2 


Dl 


DO 


I/O 


I/O 


IFB A 


INTE A 


INTR A 


INTE B 


OBF B 


INTR B 



NOTE: The Port C I/O bits D7 and Dg should be modified 
through the use of the Port C bit set/reset com- 
mand word. If a write to Port C is issued, the 
INTEa and INTEb bits may be inadve rtently 
modified by the user. The IBF A , INTR A , OBFg, 
and INTRg bits will not be modified by either a 
write to Port C or a bit set/reset command. These 
four bits always reflect the state of the interrupt 
control logic. 



Figure 8. Mode 1 Status Word 



Example #4 - MODE l STATUS WORD 

If an 8255 is to be configured through the use of 
the mode control word interface as: 

Port A Mode 1 Input 
Port B Mode 1 Output 
Port C Bits 6 & 7 Output 

The following mode control word is used: 



Note that the Mode 2 status word (shown in Fig- 
ure 9) differs from the Mode 1 status word. The 
format of the status word data bits D2— Do are 
defined by the specification of the Port B configu- 
ration. Example #5 shows the structure of the 
Mode 2 status word when the 8255 is configured 
with Port A Mode 2 (bidirectional bus) and Port B 
Mode 1 input. 

The Mode 1 and Mode 2 status words reflect the 
state of the interrrupt logic supported by the 8255. 
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Example #6 demonstrates how the interrupt 
enable bits are controlled through the use of the 
Port C bit set/reset feature. The application exam- 
ples provide a more detailed explanation of the use 
of the Port C status word in the Mode 1 and Mode 
2 configurations. 



After the 8255 mode control word has been is- 
sued, a read of Port C will obtain the following 
Mode 2 status word: 



D 7 D 6 D 5 D 4 D 3 D 2 D, D 
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INTRg 
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Example #6 - MODE 2 INTERRUPT ENABLE/ 
DISABLE 

The Mode 2 status word shown in Figure 9 con- 
tains two interrupt enable bits: 



INTE, 
INTE 2 



Bit 6 — Enable output interrupts 
Bit 4 — Enable input interrupts 



Bit set/reset control words may be constructed 
which may be used to control the INTE bits. 



Figure 9. Mode 2 Status Word 



Example #5 - MODE 2 STATUS WORD 

If the 8255 is to be configured as follows: 

Port A Mode 2 Bidirectional Bus 
Port B Mode 1 Input 

The following mode control word is used: 



°5 D 4 D 3 | D 2 | D, I Dp 



Not Used = Set to 
Port B Input = 1 



Port B Mode 1 = 1 



Not Used = Set to 00 



Port A Mode 2=10 



Opcode Mode Set = 1 



Set Bit 6 (Enable Output Interrupts ) = 
00001101 Binary 

Reset Bit 6 (Disable Output Interrupts) : 
00001 100 Binary 

Set Bit 4 (Enable Input Interrupts) = 
00001001 Binary 

Reset Bit 4 (Disable Input Interrupts) = 
00001000 Binary 



The control words shown were constructed from 
the standard bit set/reset format shown in Fig- 
ure 7. 

The value of CWR used in the following program 
example corresponds to the 8080 configuration 
shown in Figure 3. 



EOU OFBH ; 8255 =1 CONTROL WORD REGISTER 

ENABLE INTERRUPTS FOR MODE 2 OUTPUT ISET PORT C BIT 61 



MVI 
OUT 



A. 00001 101B 
CWR 



; GET SET BIT 6 CONTROL WORD 

; OUTPUT TO 8255 =1 CONTROL WORD REGISTER 



DISABLE INTERRUPTS FOR MODE 2 OUTPUT (RESET PORT C BIT 6) 



Mode Control Word = 1 1 O0O11O Binary. 



MVI 
OUT 



A, O00O1 1006 
CWR 



; GET RESET 8IT 6 CONTROL WORD 

; OUTPUT TO 8255 =1 CONTROL WORD REGIS ~ER 
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SOFTWARE CONSIDERATIONS 



Regardless of the mode selected, the software must 
always issue the correct. mode control word after a 
reset of the device. Generally, an initialization 
routine is constructed which issues the correct 
mode control word, sets up the initial state of the 
control lines, and initializes any program internal 
data. 

Many of the software requirements of the 8255 
vary as a function of the mode selected. The 
simplest mode supported by the device is Mode 
(Basic Input/Output). Generally, Mode is used 
for simple status driven device interfaces (no inter- 
rupts^. Figure 10 illustrates sample software that 
could be used to support such interfaces. Most 
devices support a BUSY or READY signal which is 
used to determine when the device is ready to 
input or output data and a DATA STROBE which 
is used to request data transfer (DATA STROBE 
may easily be generated with the Port C bit set/ 
reset feature). In the Mode configuration, Ports 
A and B are used to input/output byte oriented 
data. Port C is used to input 8255 status, periph- 
eral status and to drive peripheral control lines. 

When the Mode 1 and Mode 2 configurations are 
used the software is generally required to support 
interrupts. Software routines written for an inter- 
rupt driven environment tend to be more complex 
than status driven routines. The added complexity 
is di e to the fact that interrupt driven systems are 
constructed such that other software tasks are run 
whib the I/O transaction is in progress. A software 
routine that controls a peripheral device is gener- 
ally referred to as a device driver. One method of 
implementing an interrupt driven device driver is to 
partition the device driver into a "Command Proc- 
essor" and an "Interrupt Service Routine". The 
command processor is the module that validates 





SET UP 
DATA 






ISSUE 
STROBE 







Figure 10. Sample Status Driven Software Flowchart 



and initiates user program requests to the device 
driver. A common method of passing information 
between the various software programs is to have 
the requesting routine provide a device control 
block in memory. A sample device control block is 
shown in Table II. 



Table II. Sample Device Control Block 



NAME 


DESCRIPTION 


Status 

Opcode 
Buffer Address 
Character Count 
Character Transferred Count 
Completion Address 


This 1-byte field is used to transmit the status of the I/O transaction (busy, 
complete, etc.). 

This 1-byte field defines the type of I/O (READ, WRITE, etc.). 

This 2-byte field specifies the source/destination of the data block. 

This 1-byte field is a count of the number of characters involved in the transaction. 

This 1-byte count of the number of characters which were actually transferred. 

This 2-byte field is the address of the user supplied completion routine which will 
be called after the I/O has been performed. 
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The command processor validates the transaction 
and initiates the operation described by the control 
block. Control is then returned to the requestor so 
that other processing may proceed. The interrupt 
service routine processes the remainder of the 
transaction. 

The interrupt service routine supports the follow- 
ing functions: 

1. The state of the machine (registers, status, etc.) 
must be saved so that it may be restored after 
the interrupt is processed. 

2. The source of the interrupt must be determined. 
The hardware may support a register which indi- 
cates the interrupting device, or the software 
may poll the devices through interrogating the 
Port C status word of each 8255. 

3. Data must be passed to or from the device. 

4. Control must be passed to the requesting routine 
at the completion of the I/O. 

5. The state of the machine must be restored be- 
fore returning to the interrupted program. 




SET UP INITIAL 
STATE OF DEVICE 
DEVICE CONTROL 
BLOCK 




POST 
TO USER 
.COMPLETION, 
ROUTINE 



START 
I/O 




START 
I/O 




START 

I/O 



I 



ENABLE 
INTERRUPTS 



I RETURN 
I TO CALLER 



Figures 11 and 12 are simplified flowcharts of one 
of the many methods of implementing command 
processor and interrupt service routine modules. 

The rest of this application note presents specific 
application examples. All of the 8080 assembly 
language programs supplied with the appl cation 
examples use the standard Intel 8080 assembly 
language mnemonics. The programs discuss;d use 
the program equate statement to specify all hard- 
ware related data. Equate statements are used so 
that all references to an I/O port may be changed 
through a simple reassignment of the port address 
in the equate statement. 




Figure 11. Command Processor 



Figure 12. Interrupt Service Routine 
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MODE - STATUS DRIVEN PERIPHERAL 
INTERFACE 

This design example shows how a single 8255 in 
Mode may be used to develop a status driven 
interface (no interrupts) for the Centronics 306 
character printer, the Remex paper tape punch, 
and the Remex paper tape reader. 



8255 To Peripheral Hardware Interface 

The first step in the design is to examine the speci- 
fication for the peripheral devices and identify the 
control and data signals which must be supported 
by the interface. Table III lists the signals which 
were chosen to be supported by the 8255 inter- 
face. A.11 three of the devices support the standard 



Table III. Peripheral Interface Signals 



CHARACTER PRINTER 


Mame: 


DATA 0— DATA 7 


Definition : 


Input data levels. A high signal represents a 




binary 1 and a low signal represents a binary 




0. These eight lines are the data lines to the 




printer. 


Name: 


DATA STROBE 


Definition: 


A 0.5 Msec pulse (minimum) used to trans- 




fer data from the 8255 to the printer. 


Name: 


BUSY 


Definition: 


The level indicating that the printer cannot 




receive data. 


PAPER TAPE PUNCH 


Name: 


TRACKS 1-8 DATA INPUT 


Definition: 


Input data levels. A high signal causes a 




hole to be punched on the associated track. 




These eight lines are the data lines to the 




printer. 


Name: 


PUNCH COMMAND INPUT 


Definition: 


A true condition moves the tape and 




initiates punching the tape. This signal is 




actually a data strobe. 


Name: 


PUNCH READY OUTPUT 


Definition: 


True signal indicates that the punch is ready 




to accept a punch command. This is the 




punch busy line. 


PAPER TAPE READER 


Name: 


DATA TRACK OUTPUTS 


Definition: 


True signal indicates data track hole. These 




eight lines are the data lines from the punch. 


Name: 


DRIVE RIGHT 


Definition: 


True signal drives the tape to the right and 




reads a character. This signal is actually the 




data strobe (initiate read signal). 


Name: 


DATA READY OUTPUT 


Definition: 


True signal indicates data track outputs are 




in "On character" condition. This signal is 




the reader busy line. 



BUSY/DATA STROBE interface discussed previ- 
ously (see Figure 10). Figure 13 is a block diagram 
of the interface design. The 8255 Port A is con- 
figured as a Mode output port which is used to 
support the printer and the paper tape punch data 
bus. Port B is configured as a Mode input port 
and is used to input the paper tape reader data. 
Three of the Port C lower bits (PC 2 -PC ) config- 
ured in input mode are used to input the device 
busy indications. Three of the Port C upper bits 
(PCg— PC4) configured in output mode are used to 
support the device strobe signals required by each 
device. 

The drive requirements of the interface lines are a 
function of the peripheral interface circuitry, the 
length of the interface cable, and the environment 
in which the unit is running. In this particular de- 
sign example, all output lines from the 8255 to the 
peripherals were buffered through a 7407 buffer/ 
driver. The input lines from the peripherals were 
fed directly into the Port C and Port B inputs. 

8080 CPU Module To 825S Interface 

The schematic of the completed hardware design is 
shown in Figure 14. The CPU module design 
shown is the design which was implemented for 
Intel's SDK 80 kit board. The 8255 is addressed 
through the use of an isolated I/O architecture 
utilizing a linear select scheme. Address bits Aj and 
Ao are used to select the 8255 port. Address bit 
A3 is the exclusive enable for 8225 #1. Examina- 
tion of the schematic shows that all of the 8255 
interface lines are directly driven by the CPU 
module. 




NOTE: 

1. OUTPUT DATA BUS BUFFERED WITH 7407. 

2. ALL 8255 OUTPUT LINES ARE PULLED UP TO +5V AT THE PERIPHERAL. 



Figure 13. Interface Block Diagram 
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Mode Interface Software 

An initialization routine and three device drivers 
(one for each peripheral device) are required to 
support the peripheral interface. The I/O port 
addresses implemented by the hardware are shown 
in Figure 15. The unused chip select bits are set to 
one sc that chip select conflicts will not result if 
the unused bits are required by an expanded sys- 
tem. 



p7 | A 6 | A 5 I A 4 I A 3 | A 2 j~ A, 



ISIS 8080 MACRO ASSEMBLER, V1.0 
MODE ZERO EXAMPLE 



8255 Port Selec t 

00 Port A 

01 Port B 

10 Port C 

1 1 Control Word Regisle 
8251 Select 



= Select 

1 - No Select 



8255 =1 Select 



= Select 

1 = No Select 



8255 =2 Select 



0OF6 
0OF7 



- Select 

1 - No Select 



Spare Select Lines Set to 11 1 Binary 



TITLE 'MODE ZERO EXAMPLE ' 



CHARACTER PRINTER, PAPER TAPE PUNCH , PAPER TAPE READER 
MODE ZERO EXAMPLE 



PROGRAM EQUATES 



PORTA 
PORTB 
P0KTC 
CWR 



OFUH 
0F5H 
0F6H 
0F7H 



6255 PORT A 

8255 PORT B 

6255 POST C 

8255 CONTROL WORD REGISTER 



INITIALIZATION CONTROL WORD 

USED TO CONFIGURE THE 8255 AS FOLLOWS: 

PORT A - OUTPUT MODE ZERO 
PORT B - INPUT MODE ZERO 
PORT C (UPPER) - OUTPUT 
PORT C (LOWES) - INPUT 



Port Selected 


Port Select Character 
fin Hexadecimal) 


\ Port A 8255 =1 


F4 


Port B 8255 =1 


F5 


PortC 8255 =1 


F6 


Control Word Register 8255 = 1 


F7 


Port A 8255 =2 


EC 


Port E 8255 =2 


ED 


Port C 8255 =2 


EE 


\ Control Word Register 8255 ~2 


EF 


Figure 15. I/O Port Addresses 



0063 


ICW 


EQU 


1C00001 IE 


; INITIALIZATION CONTROL WORD 






SET/ RESET CONTROL 


WORDS FOR GENERATION OF DATA STROBES 






ON PORT C. 




000D 


LP50N 


EOU 


00001101B 


; PRINTER DATA STROBE ON 


ococ 


LFSOF 


EQU 


00001 100B 


; PRINTER DATA STROBE OFF 


0O0B 


PNSON 


EQU 


0000 7 1 16 


; PUNCH DATA STROBE ON 


000A 


PNSQF 


EQU 


OQ001QTOB 


; PUNCH DATA STROBE OFF 


0O09 


RDSON 


EQU 


000010018 


; READER DATS STROBE ON 


0008 


RDSOF 


EQU 


00001000B 


; READER DATA STROBE OFF 




.■■■ft 












BIT 


MASK FOR DEVICE BUSY CHECK 


0004 


LPBSY 


EQU 


OHH ; 


LINE PRINTER BUSY 


0002 


PNBS1 


EQU 


02H ; 


PUNCH BUSY 


0001 


RDBSY 


EQU 


01H ; 


READER BUSY 



Note that the initialization routine issues the 
mode control word (shown in Figure 16). It also 
sets the low true DATA STROBE signals to an 
inactive (high) state. 



Hardware Requirements: 

Port A - Output Mode 
Port C Upper Bus C7-C4 — Output Mode 
Port C Lower Bits C3-CQ - Input Mode 
Port B - Input Mode 



Port C Lower I/O — Input Mode 



Port B I/O - Input Mode 
Port B Mode - Set to Mode 



Port C Upper I/O - Output Mode 
Port A I/O — Output Mode 



Port A Mode — Set to Mode 



Opcode -- Mode Set = 1 



ISIS 8080 MACRO ASSEMBLER , VI. 

MODE ZERO EXSMPLE - INITIALIZATION ROUTINE 



PROGRAM ORIGIN 
ORG 03000H 



3000 3E83 
3002 P3F7 



300^ 3fcOD 
3-006 D3F7 
300S 3E09 
300 A D3F7 
300C C9 



INITIALIZATION ROUTINE 
A REGISTER MODIFIED 



MVI A, ICW ; GET INITIALIZATION CONTROL WORD 

OUT CWR ; OUTPUT TO CONTROL WORD REGISTER 

SET BLL LOW TRUE DATA STROBES ON 

MVI A.LPSON ; GET CONTROL HOKD TO TURN ON PRINTER DATA STROBE 

OUT CWR ; OUTPUT TO CONTROL WORD REGISTER 

MVI fl.BDSON ; GET CONTROL WORD TO TURN ON READER DATA ST ROB ft 

OUT CWR ; OUTPUT TO CONTROL WORD REGISTER 

BET ; RETURN TO CALLER 



Mode Control Word = 10O0OOO11 Binary = 83 HEX. 



Figure 16. Mode Control Word 
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The three peripheral drivers which follow all have 
the basic structure discussed previously. Consider 
the printer routine. Here the user routine places an 
ASCII data character in the C-register and passes 
control to the LPST location through a subroutine 
call. The printer driver interrogates the status of 
the printer by reading Port C. If the printer is busy, 
the routine will loop until the printer is idle. When 
the printer is ready to accept a data character, the 
character is placed on the Port A lines and a DATA 
STROBE is generated. After generating the DATA 
STROBE, the driver executes a subroutine return 
to the caller. 

The DATA STROBE signals to the devices are 
generated through the use of the Port C bit set/ 
reset feature. The bit set/reset control words used 
are shown in Figure 1 7. 

Summary / Conclusions 

This design example discussed the basic hardware 
and software required to handle a simple device 
interface. The 8255 will easily accommodate a 
more complex interface design which utilizes addi- 
tional interface lines supported by the peripheral. 



[dT Pe| D 5 P4|°3 D 2 Dl ° 



S et Bi t = 1, Reset B it ^ 

Brt Select 110 Binary = 6Decimal (Prin er) 
101 Binary = 5 Decimal (Puni h) 
100 Binary = 4 Decimal (Reac er) 



Not Used - Set to 00 



Bit Set/Reset Opcode = 



The control word for set Printer DATA STROBE (PC 6) = 00001 101 binary. 
The control word for reset Printer DATA STROBE (PC 6} = 00001100 binary. 
The control word for set Punch DATA STROBE (PC 5) = 00001011 binary. 
The control word fot reset Punch DATA STROBE (PC 5) - 00001010 binary. 
The control word for set Reader DATA STROBE (PC 4) - 00001001 binary. 
The control word for reset Reader DATA STROBE (PC 4) - 00001000 binary. 



Figure 17. Bit Set/Reset Control Words 



For instance, one of the spare Port C outpui lines 
may be used to control the punch direction Sup- 
port of this additional feature would require minor 
modification of the device driver so that the punch 
direction line could be specified by the user 
routine. 

Through consideration of this example, the i ,se of 
the 8255 in Mode should become evident. 





ISIS 8080 MACAO ASSEMBLER, VI. 

MODE ZERO EXAMPLE - CHARACTER PRINTER DFIVER 



CHARACTER PRINTER DRIVER 



RESET 
STROBE 



30QD DBF6 
300F E601 



30T1 79 
301 5 D3FH 
3017 3E0C 
3019 D3F7 
301B ]C 
30 1C D3F7 
301 E C9 



INPUTS : CHARACTER TO PHINT IN C-REG 
OUTPUTS: CU AH ACTEF TO PRINTER 



fl REGISTER MODIFIED 



PCRTC 
LPBSY 
LPST 



GET STATUS OF PRINTER 
SEE IF BUSY 

IF BUSY - JUMP TO LPST (WAIT LOOP) 



PRINTER IS IDLE - OUTPUT A CHARACTER 

H0V A,C ; GET DATA BYTE SUPPLIED BV CALLER 

OUI PORTA ; OUTPUT DATA TO DATA LINES 

MVI A.LPSOF ; GET DATA STROBE CONIR0L WORD 

OUT CWR ; RESET DATA STROBE (LOW TRUE SIGNAL) 

INfi A ; GENERATE SET DftTA STROBE CONTROL WORD 

OUT CWR ; SET DATA STROBE 

RET ; RETURN TO CALLER 




PRINTER DRIVER 
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ISIS 8080 MACHO ASSEMBLER , V1.0 

MODE ZERO EXAMPLE - PAPER TAPE PUNCH DRIVER 




PAPER TAPE PUNCH DRIVES 



A REGISTER MODIFIED 



ISSUE 
DATA 



RESET 
STROBE 



301 F DBF6 
3021 E602 
3023 C21F30 



3026 79 

3029 3E0B 
302fl D3F? 
302D 3D 
30 2E D3F7 

3030 C9 



PORTC 
PN3SY 
PNST 



; GET STATUS OF PUNCH 
. SEE IF BUSY 

: IF BUSY - JUMP TO PNST (WAIT LOOP) 



PUNCH IS IDLE - OUTPUT A CHARACTER 

MOV A,C ; GET DATA BYTE SUPPLIED BY CALLER 

OUT PORTA ; OUTPUT DATA TO DATA LINES 

MVI A.PNSON ; SET DATA STROBE CONTROL WORD 

OUT CtfR ; SET DATS STROBE 

DCR A ; GENERATE RESET DATA STROBE CONTROL WORD 

OUT CHP ; RESET DATA STROBE 

RET ; RETUHtf TO CALLER 



SET 

STROBE 



PUNCH DRIVER 




GET DATA 






. 

CLE 
STR 


AR 
ORE 



3031 3E06 
3033 D3F7 

30 35 DBF 6 
3C37 E601 
3039 C23530 



303C DBF5 

303E 0EO7 

30^0 3E09 

30«2 D3F7 

304 U C9 



PAPER TAPE READER DRIVER 



INPUTS : DATA FROM HEADER 

OUTPUTS: CHARACTER TO USER IN C-HEGI STER 



1! AND C REGISTER MODIFIED 



MVI A , RDSOF 

OUT CWR 

IN PORTC ; CEI STATUS OF DEVICE 

AN I RDBSY ; SEE IF BUSY 

JNZ RDLP ; IF BUSY - LOOP UNTIL IDLE 

GET CHAR AND CLf.AR STROBE 



READER NOT BUSY ■ 

IN PORTB 
MVI C,A 

A , RD30N 



GET CHARACIEft 
SAVE CHARACTER 

GET STROBE SET CONTROL WORD (LOW TRUE SIGNAL) 
CWR ; TURN OFF STROBE 

RETURN TO CALLER 



end of mode zero example 

END 



^ RETURN ^ 



READER DRIVER 
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MODE 1 INTERRUPT DRIVEN PRINTER 
INTERFACE 

The status driven interface described in the previ- 
ous example required the software driver to poll 
the device status for completion. An alternate 
approach is to construct the device interface such 
that an interrupt is used to signal the completion 
of the operation. When an interrupt driven inter- 
face is utilized, the time that was dedicated to 
polling can be used to perform other functions and 
the effective processor through-put is increased. 
This example demonstrates how an 8255 config- 
ured in Mode 1 may be used to develop an inter- 
rupt driven interface for the Centronics 306 char- 
acter printer. 



strobe signal when interfacing to 
peripherals which do not require a 
pulsed input. The Centronics 306 
requires a pulsed DATA STROBE 
signal. This signal is supported by 
Port C bit 0. 

ACK - ACKnowledge 

This line is used to signal the 8255 
that the device has accepted the 
data. This line is supported by the 
printer ACKNLG signal. 



CPU Module To 8255 Interface 

The 8080 bus interface implemented for this ex- 
ample is the same as the Mode example with the 
addition of interrupt support. Interrupt support 
is implemented through the use of a special feature 
of the 8228 System Controller. If only one inter- 
rupt vector is required (such as in small systems), 
the 8228 can automatically assert an RST 7 in- 
struction onto the data bus at the proper time. 
This option is selected by connecting the INTA 
output of the 8228 to the +12-volt supply through 
a 1 K ohm series resistor. 

The Mode 1 interrupt support logic of the 8255 
provides an interrupt request line for each port. 
The 8255 interrupt request line (INTRa) must be 
connected to the INT line of the 8080. A 10K ohm 
pullup resistor is used to insure that the Vjh re- 
quirements of the 8080 are met. 

8255 To Peripheral Interface 

The interrupt driven configuration control signal 
interface to the printer is different than the status 
driven interface. Instead of a BUSY/DATA 
STROBE interface, a DATA STROBE/ACK inter- 
face is supported. The ACK signal notifies the 
8255 that a character transferred to the printer by 
a DATA STROBE has been accepted. After an 
ACK is issued the printer is considered idle. The 
block diagram shown in Figure 18 displays the 
interface signals used. 

The Mode 1 interrupt driven peripheral support 
signals used are: 

PA7-PA0 - Output Data 

Used to support the printer data 
port. 

OBF - Output Buffer Full 

This line goes low when data is 
placed in the output buffer. The 
OBF signal may be used as a data 



TO 8080 
INT 



INTRA 










OUTPUT DATA . 






8255 

PC 


7407 






PC 6 -ACK A 










PC 7 -OBF^ 






PC 1.2,4.5 




\ NOT USED 






>l 



CHARACTI R 
PRINTER 



DATA STROBf 



NOTES: 

1. DATA BUS BUFFERED WITH 7407. 

2. ALL 8255 OUTPUT LINES ARE PULLED UP TO ^5V AT THE PERIPHERAL. 



Figure 18. Interface Block Diagram 
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Mode I Software Driver 



The software driver implemented for this example 
utilizes, the typical interrupt driven software struc- 
ture outlined previously. The initialization routine 
issues the mode control word (shown in Figure 19) 
to the 8255 after reset of the device. The initializa- 
tion routine also places a jump to the interrupt 
service routine in the interrupt location for RST 7. 
The command processor is started by the user 
routine through a subroutine call to PSTRT, with 
the address of the control block in the D and E 
registers (the control block format is shown in 
Table IV). The command processor insures that an 
I/O operation is not already in progress, starts the 
I/O, enables interrupts, and returns to the caller so 
that other processing may proceed. 

After a character is placed in the output buffer, the 
DATA STROBE signal is generated through the use 
of the Port C bit set/reset feature. When the ACK 
is generated by the printer, the buffer full indica- 
tion is cleared and the 8255 generates an interrupt. 
If interrupts are enabled, the interrupt request is 
serviced by the 8080 CPU through disabling 
processor interrupts and then executing the in- 
struct ion at location 38 hexadecimal in program 
memory. The interrupt service routine saves the 
processor state and polls the 8255 to determine 
the source of the interrupt. Once the interrupting 
device is located, the control block is used to 
locate the next data character for transfer to the 
8255 output buffer. After the entire buffer has 
been printed, the interrupt service routine passes 
control to the user-supplied completion routine. 
Before returning from the interrupt, the state of 
the processor is restored. 



Hardware Requirements: 

Port A - Input Mode 1 
Port C (Lower) - Output 

l m ^, !: ,! No. Used 
Port C fUpper) | 



° ! 1 I ° I 



Port C Set to Output Mode 



Port B Not Used Set to Input Mode 
Port B Mode Not Used Set to 



Port C I/O Set to Input 



Port A I/O Set to Output 



Port A Mode One 



Opcode - Mode Set 



Mode Control Word = 101O1010 Binary = AA HEX. 



Figure 19. Mode Control Word 



Table IV. Printer Software Control Block 



NAME 


POSITION 


DEFINITION 


Siatus 


Byte 


A 1-byte field which defines the completion status of an I/O. 

00 = Good completion 

01 = Error — command already in progress 


Buffer Address 


Byte 1, 2 


Pointer to the start of the data to print. 


Character Count 


Byte 3 


Count of the number of characters to print. 


Character 
Transferred Count 


Byte 4 


The number of characters transferred. 


Completion 
Address 


Byte 5, 6 


Address of a user supplied routine which will be called after the I/O has 
been performed. 



NOTES: 

1. An opcode field is not required because WRITE is the only operation performed. 

2. The control block must reside above location FF Hex. 
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There are a number of error conditions which may 
occur, such as an interrupt from a device which 
does not have a control block in progress, or an 
interrupt when polling establishes that no device 
requires service. Neither of these errors should 
occur, but if they do, the driver should perform in 
a consistent fashion. The recovery routines imple- 
mented to handle error conditions are determined 
by the particular applications environment. 

Summary /Conclusions 

When utilized in a small system design, the 8255 
interrupt support logic provides all of the capabili- 
ties required to implement an interrupt driven 
hardware interface without the use of external 
logic. In larger system designs, the designer may 
chose to use additional hardware to determine the 
source of interrupt requests without software 
polling. The software design required by an inter- 
rupt driven system is inherently more complex 
than the status driven interface. If an interrupt 
driven system is required the added complexity is 
a small price to pay for a significant increase in 
system through-put. 



ISIS 6080 MACRO ASSEMBIER, VI .0 
MODE CHE EXAMPLE 



TITLE MODE ONE EXAMPLE' 



CHARACTER PRINTER - INTERRUPT DRIVEN 
MODE ONE EXAMPLE 



PROGRAM EQUATES 



00F4 


PORTA 


SOU 


0F4H 


; 8255 PORT A 




PORTB 


EQU 


0F5H 


; 8255 PORT B 


00F6 


PORTC 


EQU 


0F6H 


; 8255 PORT C 


80F7 


CWR 


EQU 


0P7H 


; 8255 CONTROL WORD REGISTER 


0038 


RST7 


EQU 


038H 


; RESTART 7 ADDRESS 



STBCN 
STBOF 



1EN 
IDN 



LPBSY 
INTRA 



INITIALIZATION CONTROL WORD 

USED TO CONFIGURE THE 8255 AS FOLLOWS: 

PORT A - OUTPUT MODE 1 

PORT B - INPUT MODE (NOT USED) 

PORT C LOWER - OUTPUT 

; INITIALIZATION CONTROL WORD 



SET/RESET CONTROL WORDS 



EQU 
EQU 



' SET STROBE 
■ RESET STROBE 



8255 ENAB LE/DI SABL£ INTERRUPT CONTROL WORDS 



SOU 
EQU 



DEVICE STATUS EQUATES 
08 0H 



ECU 
EQU 



BUFFER FULL (LINE PRINTER BUSY) 
INTERRUPT REQUEST 



ISIS 8080 MAC BO ASSEMBLER, VI. 
MODE ONE EXAMPLE 



CONTROL BLOCK EQUATES 



0000 


CBST 


EQU 


00H ; 


STATUS BOTE 


0001 


CBUF 


EQU 


01H ; 


BUFFER ADDRESS 


0003 


CBCC 


EQU 


03H 


CHARACTER OOUNT 


0004 


CBCT 


EQU 


04H ; 


CHARACTER TRANS FERED COUNT 


0005 


CBCMP 


EQU 


05H ; 


COMPLETION SERVICE ADDRESS 






COMPLETION STATUS EQUATES 






STGD 


EQU 


00H ; 


GOOD COMPLETION 


0001 


STE1 


EQU 


01H ; 


ERROR - COMMAND ALREADY TN 



PROGRAM ORIGIN 



INITIALIZATION ROUTINE 
A,H,L REGISTERS MODIFIED 



3000 3EAA 
3002 D3F7 
3004 3E01 
3006 D3F7 



3008 3EC3 
300A 323800 
300D 213030 
3010 223900 
3013 C9 



MVJ A,ICW 

OUT CWR 

MV1 A, STBCN 

OUT CWR 



GET MODE CONTROL WORD 
OUTPUT TO CONTROL WORD REGISTER 
GET SET DATA STROBE CONTROL WORD 
5ET DATA STROBE (LOW THUE SIGNAL) 



SET UP RESTART 7 IDCATION WITH JUMP TO PINT 

MVI A,0C3H ; GET "JMP" 

STA RST? ; PLACE IN RST7 IDCATION 

LXI H.PINT ; GET ADDRESS OF INTERRUPT SERVICE ROUTINE 

SHU) RST7+1 ; STORE ADDRESS 

RET ; RETURN TO CAU£R 
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SET 

COMMAND 
IN PROGRESS 



CLEAR 
CT 



<CALL \ 
OUTPUT } 



ENABLE 
PROCESSOR 
INTERRUPTS 



<POST TO \ 
USER / 



ISIS 8080 MACRO ASSEMBLER, VI 
COMMAND PROCESSOR 



3014 3AA230 
3017 17 



3018 C22B30 
301B EB 
30 1C 32A130 
301F EB 
3020 210400 

3023 19 

3024 3600 
3026 CD5830 
3029 FB 
302A C9 



302B 3E01 
302D C39430 



COMMAND PROCESSOR 

INPUTS: CONTROL BLOCK ADDRESS IN D AND E REGISTERS 
OUTPUTS: START I/O CR ERROR STATUS IK CONTROL BLOCK 

A , H , L REGISTERS MODIFIED 



GET PRINT IN PROGRESS BLOCK ADDRESS 

SEE IF ZERO (PHINT IN PROGRESS) 

IF SLOCK ADDRESS NOT EQUAL TO ZERO THEN 

PRINT IN PROGRESS 

IF YES - BRANCH TO ERROR 



XCHG 

SHLD 

XCHG 

LXI 

DAD 

MVI 

CALL 

EI 

RET 

ERROR - 
MVI 



PSTE 
PIPRG 
H,CBCT 



SAVE CONTROL BLOCK ADDRESS 

GET INDEX TO CT 
COMPUTE ADDRESS OF CT 
CLEAR CT 
START I/O 

ENABLE PROCESSOR INTERRUPTS 
RETURN TO CALLER 



TRANSACTION ALREADY IN PROGRESS 



A.STE1 
POST 



I RETURN 1 



INT 7 

V 



SAVE 

REGISTERS 



ISIS 8080 MACRO ASSEMBLER, V1.0 
PRINTER INTERRUPT SERVICE ROUTINE 




RESTORE 
REGISTERS 






ENABL 
PROCE 
INTER 


E 

SSOR 
3UPTS 



3030 F5 

3031 C5 

3032 D5 



3034 DBF6 
3036 E608 
3038 CA5230 
303 B 3E0C 
303D D3F7 
303P FB 
3040 2AA130 

3043 AF 

3044 BC 

3045 CA5530 
30418 EB 
30H9 CD5630 



304C El 
3GHD Dl 
30HE CI 

304F n 

3050 FB 

3051 C9 



3052 C31C30 



PRINTER INTERRUPT SERVICE ROUTINE 
ALL REGISTERS SAVED AND RESTORED 



PUSH 


PSH 


SAVE PSH 


PUSH 


B 


SAVE REGISTER PAIR B AND C 


PUSH 


D 


SAVE REGISTER PAIR 2 AND E 


PUSH 


H 


SAVE REGISTER PAIR H AND L 


POLL 


INTERRUPT S 


URCE - SEE IF 8255 


IN 


PORTC 


GET STATUS OF DEVICE 


AN I 


INTRA 


SEE IF INT 


JZ 


PPOLL 


NO - BRANCH TO POLL OTHER DEVICES 


MVI 


A , IDN 


GET 8255 INT DISABLE CONTROL WORD 


OUT 


CHR 


DISABLE DEVICE INTERRUPTS 


EI 




ENABLE PROCESSOR INTERRUPTS 


LHLD 


PIPRG 


GET CONTROL BLOCK ADDRESS 


XRA 


A 


CLEAR A REG 


CMP 


H 


SEE IF PRINT IN PROGRESS 


JZ 


PIER 1 


NO - BRANCH TO ERROR ROUTINE 


XCHG 






CALL 


PDATA 


PRINT DATA 


RESIORE REGISTERS AND RETURN FROM INTERRUPT 


POP 


11 


RESTORE REGISTER PAIS H AND L 


POP 


D 


RESTORE REGISTER PAIR D AND E 


POP 


B 


RESTORE REGISTER FAIR B AND C 


POP 


PSH 


RESTORE PSH 


EI 




ENABLE PROCESSOR INTERRUPTS 


RET 




RETURN TO INTERRUPTED PROCESS 


POLL 


OTHER DEVICES IF ANY 




If NO OTHER DEVICES TO POLL. - USER SUPPLIED 




RECOVERY 


ROUTINE. 


JMP 


PRTN 


RETURN 


ERROR - INTERRUPT FROM IDLE DEVICE 




USER SUPPLIED ERROR RECOVERY KOUTINE 


JMP 


PRTN 


RETURN 
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ISIS 8080 HACRO ASSEMBLER, 1/1.0 
PRINTER OUTPUT DATA ROUTINE 



FACE 5 




DISABLE 
PROCESSOR 
INTERRUPTS 
EISIABLF 3255 
INTERRUPTS 




GOODCOMP 



OUTPUT 
CHARACTER 
GENERATE 
STROBE 



STORE 
STATUS 



POST TO 
USER 



PRINTER OUTPUT DATA ROUTINE 

CONTROL BLOCK ADDRESS IN D AND E REO 



3058 


DBE6 


IN 


PORTC 


GET STATUS OF DEVICE 


305A 


C680 






SEE IF BUSY (BUFFER FULL) 


305C 


CAS 130 


JZ 


PDiO 


IF BUSY - BRANCH 


305F 


2 101O0 


LXI 


H, CBCT 


GET INDEX TO CT 


3062 


19 


DAD 


D 


COMPUTE ADDRESS OF CT 


3063 


7E 


MOV 


A.M 


GET CT 


3061 


31 


INR 


M 


INC CT 


3065 


26 


DCX 


H 


DEC TO CC 


3066 


BE 


CMP 


H 


SEE IF EQUAL 


3067 


CA8A30 


JZ 


PCOMP 


IF EQUAL - DONE GO TELL USER 


306A 210100 


LXI 


H,CBUF 


GET INDEX TO BUFFER ADDRESS 


306D 


19 


DAD 


D 


COHPUTE ADDRESS OF BUFFER ADDRESS 


306E 


D5 


PUSH 


D 


SAVE D AND E REGISTERS 


3C6F 


5E 


H0V 


E,H 


GET LSB OF BUFFER ADDRESS 


3070 


23 


INX 


H 


INC TO NEXT BYTE 


307 l 


56 


HOV 


D.H 


GET BUFFER MSB 


3072 


2&00 


MVI 


H,00H 


CLEAR H REG 


307" 


6F 


HOV 


L, A 


GET CT 


307 5 


19 


DAD 


D 


COMPUTE CHAEACTER ADDRESS 


307 6 


7E 


MOV 


A, H 


GET CHARACTER 


3077 


D3FU 


OUT 


PORTA 


OUTPUT CHARACTER TO PRINTER 


3079 


3EO0 


MVI 


A , STBOF 


RESET DATA STROBE (LOW TRUE SIGNAL 


307 B 


D3F7 


OUT 


CWR 




307D 


3C 


TNR 


A 


GENERATE SET CONTROL UORD 


307E 


D3F7 


OUT 


CWR 


SET DATA STROBE 


3o8c 


D1 


POP 


D 


RESTORE COHTROL BLOCK ADDRESS 


3081 


C35630 


JMP 


PDATA 


LOOP UNTIL BUSY 






; FRINTEP BUSY - RETURN 






PD10 : 






308U 


F3 


DI 




DISABLE INTERRUPTS 


3085 


3E0D 


MVI 


A.IEN 


ENABLE DEVICE INTERRUPTS 


3067 


D3F7 


OUT 


CUR 


SET INTERRUPT ENABLE 


3089 


C9 


RET 




RETURN TO CALLER 






; POST 


GOOD COMPLETION TO USER 






PCOMP: 






308A 


3EO0 


MVI 


A , STGD 


GET GOOD STATUS CODE 






CALL 


POST 


POST TO USER 


308F 


AF 


XRA 


A 


CLEAR A REG 


309O 


32A230 


STA 


PIPRG+1 


CLEAR COMMAND IN PROGRESS ADDRESS 


3093 


C9 


RET 




RETURN TO CALLER 



^ RETURN ^ 



POST TO USER COMPLETION ROUTINE 

INPUTS : STATUS CODE IN A REG 

CONTROL BLOCK ADDRESS IN D AND E REG 

OUTPUTS: PASSES CONTROL TO USER COMPLETION ADDRES ; 
SPECIFIED IN CONTROL BLOCK 
WITH CONTROL BLOCK ADDRESS IN D AND E 



A,H,L,B,C REG MODIFIED 



3091 F.B 

3095 77 

3096 EB 

3097 270501 
309A 19 
309B HE 
309C 23 
309D 16 
309E C : j 
309F C9 
3OA0 C9 



XCHG 
MOV 
XCHG 



MOV 

PUSH 
RET 
RET 



DATA AND TABLES 



UPDATE STATUS 

GET INDEX TO COMPLETION ADDRESS 

COMPUTE ADDRESS 

GET LSB OF COMPLETION ADDRESS 

INC TO NEXT BYTE 

GET MSB OF COMPLETICN ADDRESS 

PUSH ADDRESS INTO STACK 

PASS CONTROL TO USER ROUTINE 

RETURN TO CALLER 



IN PROGRESS CONTROL ELGCK ADDRESS 

IF DATA ; NO CONTROL BLOCK IN PROGRESS 

IF DATA NOT EQUAL TO ZERO CONTROL BLOCK N PROGRESS 



END OF MODE ONE EXAMPLE 
END 
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MODE 2 - 8080 TO 8080 INTERFACE 

Due to the drastic reduction of hardware costs, 
system designs which utilize multiple CPU Modu- 
les are becoming more common. An 8080 may be 
configured as a master CPU and used to control 
multiple 8080 slave modules which act as intelli- 
gent I/O controllers. When multiple CPUs are 
utilized, a method' of processor intercommunica- 
tion must be supported. Figure 20 is a block dia- 
gram of one method of implementing a master/ 
slave interface through the use of the 8255 Mode 2 
bidirectional bus. 

Hardware Discussion 

Two complete 8080 systems are required for this 
example. Intel's SBC 80/10 OEM board is used as 
the master CPU module and Intel's SDK 80 board is 
used as the slave CPU. The SBC 80/10 supports an 
8255 which is configured in Mode 2. The 8255 is 
selected through the use of a decoded select 
scheme. Through the use of the 8228 RST 7 inter- 
rupt feature, a simple interrupt structure is sup- 
ported. The SDK 80 is configured without inter- 
rupts for this example. The external logic required 
for This example is associated with the slave CPU. 
Simple logic is imple ment ed w hich allows the slave 
CPU to generate the ACK and STB signals required 
to READ from and WRITE to the 8255 bidirec- 
tional bus with a single I/O instruction. 



The system shown in Fig ure 2 utilizes SSI logic to 
read the 8255 IBF and OBF signals. If two spare 
8255 input lines are availa ble they could be used to 
input the IBF and OBF signals and eliminate the 
SSI logic. 

Software Discussion 

Two sets of software are required to support the 
processor to processor interface. The master resi- 
dent software which follows conforms to the 
simple interrupt driven software structure outlined 
previously. The initialization routine issues the 
Mode 2 control word to the 8255 after device 
reset. The command processor accepts READ/ 
WRITE control blocks which provide a simple user 
interface for transferring data to/from the slave 
CPU. The master software is capable of processing 
both a read and a write control block simultane- 
ously. The slave resident software shown at the end 
of this example utilizes the status driven approach. 

Summary/ Conclusions 

It is important to note that this design may be ex- 
panded to include more slave CPUs by simply 
adding another 8255 to the master module for 
each slave. The software drivers discussed address 
only the passing of data between the two proces- 
sors. Specific applications generally dictate a soft- 
ware protocol be implemented for information 
transfer. 




Figure 20. Interface Block Diagram 
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ISIS 8080 MACRO ASSEMBLE*, V1.0 
MODE TWO EXAMPLE - SLAVE SOFTWARE 



OOBF 
007F 



TITLE 'MODE TWO EXAMPLE - SLAVE SOFTWARE' 



1000 MASTER TO 8080 SLAVE INTERFACE 
- SLAVE SOFTWARE - 
MODE TWO EXAMPLE 



PROGRAM EQUATES 



PDATA 
PSTS 
-•■if* 



3000 DB7F 
30O2 E601 
300H C2O030 
3007 DBBF 
30O9 
300* C9 



SLAVE READ 
ROUTINE 



EQU 
EQU 



OBFH 
07FH 



BUFFER STATUS MASKS 
EQU 



01H ; OUTPUT BUFFER F'JLL 

02H ; INPUT BUFFER FULL 



PROGRAM ORIGIN 
ORG 0300 OH 

SLAVE READ ROUTINE 



INPUTS: NONE 

OUTPUTS : CHARACTER READ IN C-REGISTER 



: REG MODIFIED 



MOV 
RET 



PSTS 

OBF 

SLRD 

PDATA 

C,A 



, GET STATUS 
SEE IF BUFFER FULL 
HO - LOOP UNTIL FULL 
GET CHARACTER 
PLACE IN C-REG 
RETURN TO CALLER 



I SLWT J 



1313 8030 MACRO ASSEMBLER, V1.0 
HOOK TVO EXAMPLE - SLAVE SOFTWARE 



GET 
STATUS 










SLAVE 


WRITE ROUTINE 










INPUTS: 


CHARACTER TO WRITE IN C 










OUTPUTS : 


NONE 








A REG 


HODIFIED 








LKT: 








30OB 


DB7F 




IN 


PSTS 


GET STATUS 


300D 


E602 




AN I 


IBF 


SEE IF BUFFER FULL 


300F 


C20B30 




JNZ 


SLWT 


1ES - LOOP UNTIL EMPTY 


3012 


79 




MOV 


A,C 


GET DATA CHARACTER 


3013 


D3BF 




OUT 


PDATA 


OUTPUT DATA 


3015 


C9 




RET 




RETURN TQ CALLER 



END OF SLAVE SOFTWARE DRIVES 



OUTPUT 
CHARACTER 



^ RETURN ^ 

SLAVE WRITE 
ROUTINE 
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ISIS aoSo MACRO ASSEMBLER, V 1 .0 
MODE TWO EXAMPLE - MASTER SOFTWARE 



PAGE 1 



TITLE 'MODE TWO EXAMPLE - MASTER SOFTWARE ' 



00E6 
0OE7 
0036 





8080 


MASTER TO 8 


80 SLAVE INTERFACE 






- MASTER 


SOFTWARE - 






MODE TWO 


EXAMPLE 




PS OCR 


AM EQUATES 




PORTA 


EQU 


OEUll 


PORT A 


POHTB 


ECU 


QE5U 


6255 PORT E 


PORTC 


EQU 


0E6fi 


8255 PORT C 


CWR 


EQU 


0E7H 


8 255 CONTROL WORD REGISTER 


R3T7 


EQU 


036H 


HESTAFT 7 ADDRESS 



INITIALIZATION CONTROL WORD 

USED TO CONFIGURE THE 8255 AS 



PORT A - MODE 2 BIDIRECTIONAL BUS 

PORT B - INPUT MODE (NOT USED) 

REMAINING FORT C LINES - INPUT MODE (NOT USED) 



OOOD 
0009 
OOOC 
OOOfl 



0008 
0080 
0020 



IENI 
IEUO 
IDNI 
IDh'O 



TNTPA 
OBFA 
TBFA 



EQU 110010113 ; INITIALIZATION CONTROL WORD 

6255 ENABLE/ DISABLE INTERRUPT CONTROL WORDS 



EQU 



00001 10 IB 
00001C01B 
00001 100B 
EQU OO0O1OOCB 

STATUS EQUATES 

08H 



ENABLE INPUT INTERRUPTS 
ENABLE OUTPUT INTERRUPTS 
DISABLE INPUT INTERRUPTS 
DISABLE OUTPUT INTERRUPTS 



EQU 



INTERRUPT REQUEST 
OUTPUT EliFFEP FULL 
INPUT BUFFER FULL 



IS 15 8080 MACRO ASSEMBLES, VI. 
MODE TWO EXAMPLE - MASTER SOFTWARE 



OOO? 
OOOi 
0OQ5 
0006 



000 
0001 
0002 



0033 

O03B C34630 



CONTROL BLOCK EQUATES 
EQU OOH 



£QU 



EQU 



GUI 



02H 



EQU 0"H 

ECU Qbii 

EQU 06fi 

OPCODE EQUATES 

EQU OOH 

KQU 01.4 



STATUS BYTE 
OPCODE.' = BEAD 

- I WRITE 
BUf-'FER ADDRKSS 
CHARACTER COUNT 
CHARACTER THANSF ERED COUNT 
COMPLETION SERVICE ADDRESS 



READ OPCODE 
WRTTE OPCODE 



COMPLETION STATUS EQUATES 

ECU OOH 
EQU 1H 

EQU 02H 

SET UF INTERRUPT VECTOR 

ORG RST7 
JMP PINT 

PROGRAM ORIGIN 

ORG 03000H 



GOOD COMPLETION 

ERROR - COMMAND ALREADY IN PROGRESS 
ESHOrt - INVALID OPCODE 



JUMP TO INTERRUPT SERVICE ROUTINE 



INITIALIZATION ROUTINE 
A REGISTER MODIFIED 



3000 3ECB 
3002 D3E7 

3001 C9 



OUT 
RET 



GET MODE CONTROL WORD 
; OUTPUT TO CONTROL WORD REGISTER 
RETSJFN TO CALLER 
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3005 210500 

3008 19 

3009 3600 
300B 210100 
300E 19 

3010 FEOO 
3012 CA2U30 
3015 FE01 
3017 CA3530 



30 IF 3E01 
3021 C3DC30 



302^ 3AEA3D 

3027 A7 

3028 C21F30 
302B EB 
302C 22E930 
302F EB 
3030 CD7C30 

3033 FB 

3034 C9 



COMMAND PROCESSOR 

INPUTS : CONTROL BLOCK ADDRESS IN D AND E REGISTERS 



MOV 
CPI 



M,OPRD 
H,CBCP 



PSRD 
OPWT 
PSWT 



GET INDEX TO CT 
COMPUTE ADDFESS OF CT 
CLEAR CT 

GET INDEX TO OPCODE 

COMPUTE ADDRESS 

GET OPCODE 

SEE IF READ 

YES - GO PROCESS READ 

SEE IF WRITE 

YES - GO PROCESS WRITE 



INVALID OPCODE 



A,STE2 ; GET ERROR STATUS CODE 
POST ; CALL COMPLETION ROUTINE 



ERROR - TRANSACTION ALREADY IN PROGRESS 



MVI A.STE1 
JMP POST 



GET ERROR STATUS CODE 
CALL COMPLETION ROUTINE 



PROCESS READ COMMAND 



JNZ 
XCHG 
SHLD 
XCHG 
CALL 



GET READ IN PROGRESS ADDRESS 

SEE IF READ IN PROGRESS (TEST FOR ZERC ) 

IF YES - BRANCH 

SAVE CONTROL BLOCK ADDRESS 

START I/O 

ENABLE INTERRUPTS 

RETURN TO CALLER 



ISIS 8080 MACRO ASSEMBLER, 
COMMAND PROCESSOR 



ENABLE 

PROCESSOR 

INTERRUPTS 



30J5 3AEC30 

3038 A7 

3039 C21F30 
303C EB 
303D 22EB30 
301(0 EB 
3041 CD9C30 

3044 FB 

3045 C9 



PROCESS WRITE COMMAND 



LDA 
ANA 

JNZ 

XCHG 

SHLD 

XCHG 

CALL 

EI 

RET 



GET WRITE IN PROGRESS ADDRESS 

SEE IF WRITE IN PROCFESS (TEST FOR ZER 1) 

IF YES - BRANCH 

SAVE CONTROL BLOCK ADDRESS 

START I/O 

ENABLE INTERRUPTS 

RETURN TO CALLER 
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INT 7 
I PINT I 



SAVE 

REGISTERS 




POLL OTHER 
DEVICES & 
PROCESS 



DISABLE 
8255 

INTERRUPTS 



ENABLE 

PROCESSOR 

INTERRUPTS 




3:;1a DBEt 

yOUL E606 

30^E CA763!) 

"3051 3E0C 

3C53 vym 



105 ' 



3 ton 



3057 D.jE7 
3059 FE 
30bA 2AE9 30 
3C5D AF 
305 E BC 
3'J5F CAt-530 
3062 CD7C30 

306b 2AEP.30 
3068 AT 
^C69 BC 
306fl CA7030 
306D CD9C30 



3070 El 

3071 D? 

3072 C1 

3073 Fl 
3071 FB 
5075 C9 



PUSH 
PUSH 
PUSH 



SAVE PSW 

SAVE REGISTER PAIR E ANL i 

SAVE REGISTER PAIJi D AND i 

SAVE REGISTER PAIR H AND i 



ixl;, interrupt scarce: - see if 8?^ 



PGRTC 
INTRA 
PPCLL 
A , I DN I 



GET STATUS OK DEVICE 
SEE IF INT 

NO - BRANCH TO POl.I. OTHER UK VICES 1F 
Ot-JT INPUT INT DISABLE CONTROL WORD 
DISABLE' DEVICE INTERRUPTS 

get output int d:saelf: CONTROL WORD 

DISAPE DEVICE INTERRUPT.'.' 
ENABLE PROCES.SGft INTERRUPTS 
GET READ CONTROL. BLOCK 
CLEAR A REG 

SEE IE READ IN FROGRESS 
NO - BRANCH 
DO I NPUT 

GET WRITK CONTROL BLOCK 
CLEAR A PEG 
, SEE IF WRITE IN PROGRESS 
NO - BRANCH 
DO OUTPUT 



RESTORE REGISTERS AND RETURN FROM INTERRUPT 



RESTORE REGISTER PAIR K AND L 
RESTORE REGISTER PAIR D AND E 
RESTORE REGISTER PAIfi E AND C 
RESTORE PSW 

ENABLE PROCESSOR INTERRUPTS 
RETURN TO INTERRUPTED PROCESS 



ISIS 8080 MACHO ASSEMBLER, n. 1 
INTERRUPT SERVICE ROUTINE 



POLL OTHER DEUCES !!■ ANY 

IF NO OTHER DEVICE: 
RECOVERY ROUTINE. 



TC FCLL - USER SUPPLIED ERROR 



3076 C37030 



3079 C37O30 



■ INTERRUPT FROM IDLE liEVICE 
iiSEfl .SUPPLIED FJRKOP RECOVERY ROUTINE 



ENABLE 

PROCESSOR 

INTERRUPTS 
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DISABLE 
PROCESSOR 
INTERRUPTS 






ENABL 
INPUT 
INTER 


E 

RUPTS 



ISIS 8060 MACRO ASSEMBLER 
INPUT DATA ROUTINE 



307C DBE6 
307E E620 
308Q CA9t30 
3063 CDBC30 
3086 DA6F30 
30E9 DBEJJ 
308B 77 
306C C37C30 



30EF AF 
3090 32EA30 
3093 C39630 



3096 F3 

3097 3EOD 
3099 D3E7 
309B C9 



INPUT DATA ROUTINE 



PRTI 
CBFA 
PI DON 
PORTA 
H , A 
PIN 



GET STATUS OF DEVICE 

SEE IF INPUT BUFFER FULL 

NC - BRANCH 

GET ADDRESS IN BUFFER 

IF DONE - BRANCH 

GET DATA 

PLACE IN BUFFER 

LOOP 



END OF INPUT TRANSACTION 



CLEAR A 

CLEAR HEAD IN PROGRESS 
RETURN 



RETURN FROM INPUT 



DISABLE PROCESSOR INTERRUPTS 

GET ENABLE INPUT INTERRUPTS CONTROL HOI D 

OUTPUT TO CONTROL HORD REGISTER 

RETURN TO CALLER 






OUTPUT 
TO 8255 







DISABLE 
PROCESSOR 
INTERRUPTS 



ENABLE 
OUTPUT 
INTERRUPTS 



/ \ 

I RETURN I 



ISIS 8080 MACRO ASSEMBLER , 
OUTPUT DATA ROUTINE 



309C DBE6 
309 E E620 

30A3 CDBC30 
30A6 DAAF30 
30A9 7E 
30AA D3E1 
30AC C39C30 



30AF AF 

30 BO 32EC30 

30E3 C3B630 



30B6 F3 
30B7 3E09 
30B9 D3E7 
30BB C9 



OUTPUT DATA ROUTINE 



AN 1 

JNZ 

CALL 

JC 

MOV 

OUT 

JHP 



POFTC 

IBFA 

PRTO 

CBFA 

PODON 

A ,M 

PORTA 

POUT 



GET PORTC STATUS 
; SEE IF OUTPUT BUFFER FULL 

IBS - BRANCH 
; SET Up ADDRESS OF DATA 

IF DONE - BRANCH 
, GET DATA FROM BUFFEfi 
; OUTPUT DATA 

LOOP 



END OF OUTPUT TRANSACTION 



PRGWT+1 

PRTO 



CLEAR A REG 

CLEAR WHITE IN PROGRESS 
RETURN 



RETURN FROM OUTPUT 



MVI 

OUT 
RET 



DISABLE PROCESSOR INTERRUPTS 

GET ENABLE OUTPUT INTERRUPTS CONTROL HORD 

OUTPUT TO CONTROL HORD REGISTER 

RETURN TO CALLER 
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^ CBFA ^ 



ISIS 80B0 MACHO ASSEHBLER, VI. 
COMPUTE BUFFER ADDRESS ROUTINE 



COMPUTE BUFFER ADDRESS ROUTINE 




Setup Buffer Address Subroutine 



30BC 




LXI 


H,CBCT 


GET INDEX TO CT 


30 Br 


19 


DAD 


D 


COMPUTE ADDRESS OF CT 


30co 


7E 


MOV 


A , M 


GET CT 


30C1 


3D 


INR 


M 


INC CT 


30C2 


23 


DCX 


H 


DEC TO CC 


30C3 


BE 


CMP 


H 


SEE IF EQUAL 


30Ct 


CAD530 


JZ 


PCOHP 


IF EQUAL - DOME GO TELL USER 


3CC7 




LXI 


H.CBUF 


cet Index to buffer address 


30CA 


19 


DAD 


D 


COMPUTE ADDRESS CF BUFFER ADDRESS 


30CB 


D5 


PUSH 


D 


SAVE D AND E REGISTERS 


30CC 


5E 


MOV 


E,H 


GET LSB OF BUFFER ADDRESS 


30CD 


23 


INX 


H 


INC TO NEXT BfTE 


30CE 


56 


MOV 


D ,M 


GET BUFFER MSB 


30CF 


AC 


XRA 


H 


CLEAR H REG 


3odo 


6F 


MOV 


L , A 


GET CT 


30DI 


19 


DAD 


D 


COMPUTE CHARACTER ADDRESS 


30D2 


D' 


POP 


D 


RESTORE CONTROL BLOCK ADDRESS 


30D3 


AF 


XRA 


A 


CLEAR CARRY 


30D4 


C9 


RET 




RETURN TO CALLER 



ISIS 80S0 MACRO ASSEMBLER, VI. 
POST TO USER COMPLETION ROUTINt 



3DD-3 3E00 
3CD7 CDDC3 
30DA 37 
30DB C9 



POST GOOD COMPLETION TO USES 



GET GOOD STATUS CODE 
CALL USER ROUTINE 
SET CARRY 
flETURN TO CALLER 



POST TO USER COMPLETION ROUTINE 



STATUS CODE IN A REG 

CONTROL BLOCK ADDRESS IN D AND E REG 
PASSES CONTROL TO USER COMPLETION ADDRESS 
SPECIFIED IN CONTROL BLOCK 



30DC 


EB 


XCHG 






30DD 


77 


MOV 


K, A 


UPDATE STATUS 


30DE 


EB 


XCHG 






30 DF 


210600 


LXI 


H, CBCMP 


GET INDEX TO COMPLETION ADDRESS 


30E2 


19 


.DAD 


D 


COMPUTE ADDRESS 


3CE3 


Jit 


MOV 


C,M 


GET LSB OF COMPLETION ADDRESS 


30ElJ 


23 


INX 


H 


INC TO NEXT BYTE 


30F_b 


46 


MOV 


B,H 


GET MSB BYTE OF COMPLETION ADDRESS 


30E6 


C5 


PUSH 


B 


PUSH ADDRESS INTO STACK 


30E7 


C9 


RET 




PASS CONIROL TO USER ROUTINE 


30E8 


C9 


RET 




REIURN TO CALLER 






; DATA 


AND TABLES 










IF DATA HON ZERO CONTROL BLOCK IN PROGRESS 


30E9 


0000 


PRGRD : DH 





IN PROGRESS READ CONTROL BLOCK 


30EB 


0000 


PRGWT: DW 





IN PROGRESS WRITE CONTROL BLOCK 



END OF MASTER SOFTWARE DRIVER 
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APPENDIX A - 8255 QUICK REFERENCE 



CONTROL WORD 



PORT C (LOWER - PC 3 -PC Q ) 
1 = INPUT 
= OUTPUT 



PORT B 
1 = INPUT 
= OUTPUT 

MODE SELECTION 

= MODE 

1 = MODE 1 



PORT C (UPPER - PC 7 -PC 4 ) 
1 - INPUT 
= OUTPUT 



PORT A 
1 = INPUT 
= OUTPUT 



MODE SELECTION 

00 = MODE 

01 = MODE 1 
IX = MODE 2 



1 = MODE SET 



MODE CONTROL WORD 



°7 


°6 


D 5 


D 4 


D 3 D 2 


D, 


D 



GROUP A 
STATUS 



INTE-i IBF 



INTEn INTRa 



GROUP B 
STATUS 



MODE 
IMPUT/OUTPUT 



MODE 1 
INPUT 

PORT 



MODE 1 
OUTPUT 
PORT 



INTEo OBF R I MTRo 



MODE 1 STATUS WORD 



CONTROL WORD 



Dc D. D 4 D, D 9 D 



PORT C BITS 



SET/RESET FLAG 



X 



- RESET BIT 

1 = SET BIT 



INPUT 

PORT 



NOT USED SET TO 000 



D 3 


D 2 


D 1 


PORT C BIT 











BIT 








1 


BIT 1 





1 





BIT 2 





1 


1 


BIT 3 


1 








BIT 4 


1 





1 


BIT 5 


1 


1 





BIT 6 


1 


1 


1 


BIT 7 



°7 


°6 


°5 


D 4 


°3 


I/O 


I/O 


IBF fl 


INTE A 


INTR A 








OUTPUT 
PORT 






i 






D 7 


D 6 


D 5 


°4 


D 3 


OBF fl 


INTE A 


I/O 


I/O 


INTR A 



GROUP A 
STATUS 



GROUP B 
STATUS 
INPUT 
PORT 



OUTPUT 
PORT 



INTE R OBF r 



= BIT SET/RESET 



BIT SET/RESET CONTROL WORD 



MODE 2 STATUS WORD 
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MODE 1 CONFIGURATIONS 



CONTROL VORD 
D 7 D 6 [. 5 D 4 D 3 D 2 D-, D 



10 I 11/0 10 



PC G ,7 



-1 = INPUT 
= OUTPUT 



PA 7 -PA 
PC 4 
PC 5 
PC 3 
PC 6 ,7 

PB7-PB0 
PC, 
PC 2 
PC 





D 7 D 6 D 5 


D 4 


D 3 D 2 D, D 




1 1 1 1 1 


1 


,/0| 1 1 [X] 


STB fl 




PC4.5 
— «-1 = INPUT 



INTR A 



OBF B 



INTRg 



PORT A - STROBED INPUT 
PORT B - STROBED OUTPUT 



CONTROL WORD 



PA 7 -PA 



PC 3 
PC4.5 
PB 7 -PB 
PC 2 



OBF A 



■ ACK fl 



PORT A - STROBED OUTPUT 
PORT B - STROBED INPUT 



■ STB B 



IBF B 



INTRg 



CONTROL WORD 
D 7 D 6 l) 5 D 4 D 3 D 2 D, D 

10 1110 11 rvi 



-1 = INPUT 
^ OUTPUT 



PA 7 -PA 
PC4 

pc 5 

PC3 
PC 6 ,7 
PB 7 -PB 
PC 2 
PCl 
PC 



CONTROL WORD 
° 7 D 6 D 5 D 4 D 3 D 2 D, D 

loii 1/0 1 I rvl 



STB fl 
IBF A 
INTR A 



PC4.5 
-1 = INPUT 
= OUTPUT 



STBg 



IBF B 



INTRg 



PA7PA0 



PC 6 



PC3 



PC4.5 



PB 7 -PB 



PC 2 



PC 



PORT A - STROBED INPUT 
PORT B - STROBED INPUT 



PORT A - STROBED OUTPUT 
PORT B - STROBED OUTPUT 



OBFfl 



ACK A 



INTRfl 



OBF B 



INTRg 
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MODE 2 CONFIGURATIONS 



CONTROL WORD 
D 7 D 6 °5 D 4 D 3 D 2 Dt Dq 



PC2-0 - 

1 - INPUT 
= OUTPUT 



p C 3 



PA 7 -PA 



A 



PC 7 



pc 6 



PC 4 



pc 5 



PC2-0 



PB 7 -PB 



INTR A 



OBF fl 



ACK A 



STB fl 



Jv 



PORT A - MODE 2 
PORT B - MODE INPUT 



CONTROL WORD 
D 7 D 6 D 5 D 4 D 3 D 2 Dt Dq 

1 = INPUT 
= OUTPUT 



PC3 



PA 7 -PA 



PC 7 



p C 6 



PC 5 



PB 7 -PB 



INTR A 



OBF fl 



ACKfl 



IBFfl 



PORT A - MODE 2 
PORT B - MODE INPUT 



CONTROL WORD 
° 7 °6 °5 ° 4 °3 °2 D, D 



pc 3 

PA 7 -PA 



PC 4 
PCs 
PB 7 - PBq 
PC, 
PC 2 
PC 



INTR A 

OBFfl 
ACKfl 
STBfl 
IBFfl 

OBF B 
AC Kg 
INTR B 



CONTROL WORD 
D 7 D 6 D S D 4 D 3 D 2 D, D 



PORT A - MODE 2 

PORT B - MODE 1 OUTPUT 



PC 3 
PA 7 -PA 
PC 7 
PC 6 
PC 4 

pc 6 

PB 7 -PB 
PC 2 
PC, 
PC 



PORT A - MODE 2 

PORT B - MODE 1 OUTPUT 



V 



OBFfl 
ACKfl 
STBfl 
IBFfl 



IFB B 
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U.S. AND 



CANADIAN SALES 



OFFICES 



ALABAMA 

Barnhill and Associates 
7844 Horseshoe Trail 
Huntsville 35802 
Tel: (205) 883-9394 

ARIZONA 

Sales Engineering, Inc. 
7155 E. Thomas Road, No. 6 
Scotlsdale 85252 
Tel: (602) 945-5781 
TWX: 910-950-1288 

CALIFORNIA 

Intel Corp." 

990 E. Arques Ave. 

Suite 112 

Sunnyvale 94086 

Tel: (408) 738-3870 

TWX: 910-339-9279 

Mac-I 

P.O. Box 1420 
Cupertino 95014 
Tel: (408) 257-9880 
Earle Associates, Inc. 
4433 Convoy Street 
Suite A 

San Diego 92111 
Tel: (714) 278-5441 
TWX: 910-335-1585 
Intel Corp." 
1651 East 4th Street 
Suite 228 
Santa Ana 92701 
Tel: (714) 835-9642 
TWX: 910-595-1114 

COLORADO 

Intel Corp. 

12075 East 45th Avenue 
Suite 310 
Denver 80239 
Tel: (303) 373-4920 
TWX: 910-932-0322 

FLORIDA 

Intel Corp. 

1090 NE 27th Terrace 
Pornpano Beach 33062 
Tel: (305) 781-7450 
TWX: 510-956-9407 



FLORIDA (cont.) 

Intel Corp. 

5151 Adanson Street, Suite 200-3 
Orlando 32804 
Tel: (305) 628-2393 
TWX: 810-853-9219 

ILLINOIS 

Intel Corp." 
900 Jorie Boulevard 
Suite 138 
Oakbrook 60521 
Tel: (312) 325-9510 
TWX: 910-651-5881 

IOWA 

Technical Representatives, Inc. 
1703 Hillside Drive 
Cedar Rapids 
Tel: (319) 396-5662 

KANSAS 

Technical Representatives, Inc. 

801 Clairborne 

Olathe 66061 

Tel (913) 782-1177 

TWX: 910-749-6412 

MARYLAND 

Barnhill and Associates 
57 West Timonium Road 
Titnonium 21093 
Tel: (301) 252-7742 

Intel Corp. * 

57 West Timonium Road 
Suite 307 
Timonium 21093 
Tel: (301) 252-7742 
TWX: 710-232-1807 

MASSACHUSETS 

Datcom 

55 Moody Street 
Waltham 02154 
Tel: (617) 891-4600 
TELEX: 92-3462 

Intel Corp." 

187 Billerica Road, Suite 14A 
Chelmsford 01824 
Tel: (617) 861-1136 
TWX: 710-343-6333 



MICHIGAN 

Intel Corp. 

725 South Adams Road 
Suite 288 

Birmingham 48011 
Tel: (313) 642-7018 
TWX: 910-420-1212 
TELEX: 2 31 143 

MINNESOTA 

Intel Corp. 

675 Southgate Office Plaza 
5001 West 80th Street 
Bloomington 55437 
Tel: (612) 835-6722 
TWX: 910-576-2867 

MISSOURI 

Technical Representatives, Inc. 

Trade Center Bldg. 

300 Brookes Drive, Suite 108 

Hazelwood 63042 

Tel: (314) 731-5200 

TWX: 910-762-0618 

NEW JERSEY 

Intel Corp. 
2 Kilmer Road 
Edison 08817 
Tel: (201) 985-9100 
TWX: 710-480-6238 



NEW YORK 

Intel Corp.* 

6901 Jericho Turnpike 

Syosset 11791 

Tel: (516) 364-9860 

TWX: 510-221-2198 

Intel Corp. 

474 Thurston Road 

Rochester, N.Y. 14619 

Tel: (716) 328-7340 

TWX: 510-253-3841 

T-Squared 

3522 James Street 

Syracuse 13206 

Tel: (315) 463-8592 

TWX: 710 541-0554 



NEW YORK (conl.) 

T-Squared 

640 Craig Road 

P.O. Box W 

Pittsford 14534 

Tel: (716) 381-2551 

TELEX: 97-8289 

Intel Corp. 

55 Market Street 

Poughkeepsie, New York 12601 

Tel: (91 4) 473-2303 

TWX: 510-248-0060 

NORTH CAROLINA 

Barnhill and Associates 
913 Plateau Lane 
Raleigh 27609 
Tel: (919) 876-5617 

OHIO 

Intel Corp." 

8312 North Main Street 

Dayton 45415 

Tel : (51 3) 890-5350 

TELEX: 288-004 

Intel Corp." 

27801 Euclid Ave. 

Suite 450 

Euclid 44132 

Tel: (216) 289-0101 

PENNSYLVANIA 

Vantage Sales Company 
21 Bala Avenue 
Bala Cynwyd 19004 
Tel: (215)667-0990 
TWX: 510-662-5846 
Intel Corp.* 
1777Walton Rd. 
Suite 328A 
Blue Bell 19422 
Tel: (215) 542-9444 
TWX: 510-661-0709 



TENNESSEE 

Barnhill and Associates 
206 Chickasaw Drive 
Johnson City 37601 
Tel: (615) 928-0184 

TEXAS 

Evans & McDowell Associates 

13777 H. Central Expressway 

Suite 405 

Dallas 75231 

Tel: (214) 238-7157 

TWX: 910-867-4763 

Evans & McDowell Associates 

6610 Harwin Avenue, Suite 125 

Houston 77036 

Tel: (713) 783-2900 

Intel Corp." 

6350 L.B.J. Freeway 

Suite 178 

Dallas 75240 

Tel. (214) 661-8829 

TWX: 910-860-5487 

VIRGINIA 

Barnhill and Associates 
P.O. Box 1104 
Lynchburg 24505 
Tel: (804) 846-4624 

WASHINGTON 

E.S./Chase Co. 
P.O. Box 80903 
Seattle 98108 
Tel: (206) 762-4824 
Twx: 910-444-2298 



CANADA 

Multilek, Inc. 
4 Barren Street 
Ottawa, Ontario K2J 1G2 
Tel: (613)825-4695 
TELEX: 053-4585 



EUROPEAN MARKETING OFFICES 



BELGIUM 

Intel International* 
Rue du Moulin a Papier 
51-Boite 1 
B-1160 Brussels 
Tel: (02) 660 30 10 
TELEX: 24814 



FRANCE 

Intel Corporation, S.A.R.L.' 
74, Rue D'Arcuei! 
Silic 223 

94528 Rungis Cedex 
Tel: (01) 68 7 2 2 21 
TELEX: 270475 



SCANDINAVIA 

Intel Scandinavia A/S* 
Lyngbyvej 32 2nd FJoor 
DK-2100 Copenhagen East 
Denmark 

Tel: (01) 18 20 00 
TELEX: 19567 
Intel Sweden AB* 
Box 86 

S-16212 Vallrngby 1 
Sweden 

Tel: (08) 37 53 70 
TELEX: 13164 (ABCENT) 



ENGLAND 

Intel Corporation (U.K.) Ltd.* 

Broadfield House 

4 Between Towns Road 

Cowley, Oxford OX4 3NB 

Tel: (0865) 77 14 31 

TELEX: 837203 

Intel Corporation (U.K.) Ltd. 

46-50 Beam street 

Nantwich, Cheschire CW5 5LJ 

Tel: (0270) 62 65 60 

TELEX: 36620 



GERMANY 

Intel Semiconductor GrrbH* 

Wolfratshauserstrasse 159 

D8 Munich 71 

Tel: (089! 79 89 23 

TELEX: 5-212870 

Intel Semiconductor GmbH 

D-6272 Niedernhausen 

Wiesenweg 26 

Tel: (06127) 2314 

TELEX: 04186183 

Intel Semiconductor GmoH 

D-7000 Stuttgart 80 

Ernsthaldenstrasse 17 

Tel: (0711) 7351506 

TELEX: 7255346 



ORIENT MARKETING OFFICES 



JAPAN 

Intel Japan Corporation* 

Flower HiM-Shinmachi East Bldg. 

1-23-9, Shinmacfu, Setagaya-ku 

Tokyo 154 

Tel: (03) 426-9261 

TELEX: 781-28426 



HONG KONG 

Q1 (Far East) Ltd. 

Tak Yan Commercial Bldg. 6th floor 

30-32 D'Aguilar Street, Central 

Hong Kong 

Tel: 5-260311 

TELEX: 83138 JADE HX 



TAIWAN 

Taiwan Automation Co." 
8th Floor, 140, Section 1 
Chung Hsiao E. Road 
Taipei 

Tel: 393-1115 

TELEX: 1 1942 TAIAUTO 



TAIWAN (cont.) 

Asionics-Taiwan, Inc. 

205 Pa-Teh Road, Section 4 

Taipei 

Tel: 75 55 82 

TELEX: 22158 Asionics 



INTERNATIONAL DISTRIBUTORS 



AUSTRALIA 

A.J. Ferguson (Adelaide) PTY, Ltd. 

44 Prospect Rd. 

Prospect 5082 

South Australia 

Tel: 269-1244 

TELEX: 82635 

AUSTRIA 

Bacher Elektronische Gerate GmbH 

Meidlinger Hauptstrasse 78 

A 1120 Vienna 

Tel: (0222) 83 63 96 

TELEX: (01) 1532 

BELGIUM 

Inelco Belgium S.A. 
Avenue Val Duchesse, 3 
B-1160 Brussels 
Tel: (02) 660 00 12 
TELEX: 25441 

DENMARK 

Scandinavian Semiconductor 
Supply A/S 
Nannasgade 18 
DK-2200 Copenhagen N 
Tel: (01) 93 50 90 
TELEX: 19037 



FINLAND 

Oy Fintronic AB 
Karjalankatu 2C, 
SF 00520 
Helsinki 52 
Tel: (90) 664 451 
TELEX: 12426 

FRANCE 

Tekelec Airtronic 
Cite des Bruyeres 
Rue Carle Vernet 
92310 Sevres 
Tel: (1) 027 75 35 
TELEX: 250997 

GERMANY 

Alfred Neye Enatachnik GmbH 

Schillerstrasse 14 

D-2085 Quickborn-Hamburg 

Tel: (04106) 6121 

TELEX: 02-13590 

Electronic 2000 Vertriebs GmbH 

Neumarketer Strasse 75 

D-8000 Muenchen 80 

Tel: (089) 434061 

TELEX: 484426 

Jermyn GmbH 

Posttach 1146 

D-6277 Kamberg 

Tel: (06434) 6005 

TELEX: 484426 



HONG KONG 

ASTEC International 
Keystone House, 2nd Floor 
Hankow Road, Kowloon 
Tel: 3-687760 
TELEX: 74899 ASCOM 

ISRAEL 

Telsys Ltd. 
54, Jabotinsky Road 
IL-Ramat-Gan 52 464 
Tel: (3) 73 98 65 
TELEX: 32392 
Eastronlcs Lid. 
11 Rozanis Street 
P.O. Box 39300 
Tel-Aviv 
Tel: 475151 
TELEX: 33638 

ITALY 

Eledra 3S S.P.A. 

Viale Elvezia, 18 

20154 Milan, 

Tel: (02) 3493041 

TELEX: 39332 

Eledra 3S S.P.A. 

Via Giuseppe Valmarana, 63 

00139 Rome, Italy 

Tel: (06) 81 27 290 -81 27 324 



JAPAN 

Pan Electron 
No. 1 Higashikata-Machi 
Midori-Ku, Yokohama 226 
Tel: (045)471-8811 
TELEX: 781-4773 

NETHERLANDS 

Inelco Mederland 
AFD Eleklronic 
Joan Muyskenweg 22 
NL-1006 Amsterdam 
Tel: (020) 934824 
TELEX: 14622 

NORWAY 

Nordisk Elektronik (Norge) A/S 
Mustads Vei 1 
N-Oslo 2 

Tel: (02) 55 38 93 
TELEX: 16963 

SOUTH AFRICA 

Electronic Building Elements 

P.O. Box 4609 

Pretoria 

Tel: 78 92 21 

TELEX: 30181 

SPAIN 

Interface 

Ronda General Mitre *7 
E-Barcelona 17 
Tel: (93) 203-53-30 
TELEX: 52838 



SWEDEN 

Nordisk Eleclronik AB 
Fack 

S-10380 Stockholm 7 
Tel: (08) 248340 
TELEX: 10547 

SWITZERLAND 

Industrade AG 
Gemsenstrasse 2 
Poslcheck 80 - 21190 
CH-8021 Zurich 
Tel: (01) 60 22 30 
TELEX: 56788 

UNITED KINGDOM 

Rapid Recall, Ltd. 

11-15 Betterton Street 

Drury Lane 

London WC2H 9BS 

Tel: (01) 379-6741 

TELEX: 28752 

G.E.C. Semiconductors Ltd 

East Lane 

Wembley HA9 7PP 

Middlesex 

Tel: (01) 904-9303 

TELEX. 923429 

Jermyn Industries 

Bestry, Sevenoaks Road 

Sevenoaks, Kent. 

Tel: (0732) 51174 

TELEX: 95143 

•Field Application Location 



U.S. AND CANADIAN DISTRIBUTORS 



ALABAMA 

tHamilton/Avnet Electronics 
805 Oser Drive NW 
Huntsville 35805 
Tel: (205) 533-1170 

ARIZONA 

Cramer/Arizona 
2643 East University Drive 
Phoenix 85034 
Tel: (602) 263-1112 
Hamilton/Avnet Electronics 
2615 South 21st Street 
Phoenix 85034 
Tel. (602) 275-7851 
Liberty /Arizona 
3130 N. 27th Avenue 
Phoenix 85107 
Tel: (602) 257-1272 
TELEX: 910-951-4282 

CALIFORNIA 

tHamilton/Avnet Electronics 
575 E. Middlefield Road 
Mountain View 94040 
Tel: (415) 961-7000 
f Hamilton/Avnet Electronics 
8917 Complex Drive 
San Diego 92123 
Tel: (714) 279-2421 
t Hamilton Electro Sales 
10912 W. Washington Boulevard 
Culver City 90230 
Tel: (213) 558-2121 
tCramer/San Francisco 
720 Palomar Avenue 
Sunnyvale 94086 
Tel: (408) 739-301 1 
fCramer/Los Angeles 
1720 Daimler Street 
Irvine 92705 
Tel: (714) 979-3000 

Cramer/San Diego 
8975 Complex Drive 
San Diego 92123 
Tel: (714) 565-1881 

(Liberty Electronics 
124 Maryland Street 
El Segundo 90245 
Tel: (213) 322-8100 
Tel: (714) 638-7601 
TWX: 910-348-7140 

Liberty/San Diego 
8248 Mercury Court 
San Diego 92111 
Tel: (714) 565-9171 
TELEX: 910-335-1590 

Elmar Electronics 
2288 Charleston Road 
Mountain View 94040 
Tel: (415) 961-3611 
TELEX: 910-379-6437 

COLORADO 

Cramer/Denver 

5465 E. Evans PI. at Hudson 

Denver 80222 

Tel: (303)758-2100 

Elmar/Denver 
6777 E. 50th Avenue 
Commerce City 80022 
Tel: (303) 287-9611 
TWX: 910-936-0770 

f Hamilton/Avnet Electronics 
5921 No. Broadway 
Denver 80216 
Tel: (303) 534-1212 

CONNECTICUT 

Cramer/Connecticut 
35 Dodge Avenue 
North Haven 06473 
Tel: (203) 239-5641 
Components Plus 
361 W. State 
Westport 08880 
Tel: (203) 226-4731 
Hamilton/Avnet Electronics 
643 Danbury Road 
Georgetown 09829 
Tel: (203) 762-0361 

FLORIDA 

Cramer/E.W. Hollywood 
4035 No. 29th Avenue 
Hollywood 33020 
Tel: (305) 923-8181 
f Hamilton/Avnet Electronics 
4020 No. 29th Ave. 
Hollywood 33021 
Tel: (305) 925-5401 
tCramer/EW Orlando 
345 No. Graham Ave. 
Orlando 32814 
Tel: (305) 894-1511 



GEORGIA 

Cramer/EW Atlanta 
3923 Oakclift Industrial Center 
Atlanta 30340 
Tel: (404) 448-9050 
Hamilton/Avnet Electronics 
6700 I 85, Access Road, Suite 2B 
Norcross 30071 
Tel: (404) 448-0800 

ILLINOIS 

tCramer/Chicago 

1911 So. Busse Rd. 

Mt. Prospect 60056 

Tel: (312) 593-8230 

f Hamilton/Avnet Electronics 

3901 No. 25th Ave. 

Schiller Park 60176 

Tel: (312) 678-6310 

INDIANA 

Pioneer/Indiana 
6408 Castleplace Drive 
Indianapolis 46250 
Tel: (317) 547-7777 
Sheridan Sales Co. 
8790 Purdue Road 
Indianapolis 46268 
Tel: (317) 297-3146 

KANSAS 

Hamilton/Avnet Electronics 
37 Lenexa Industrial Center 
9900 Pflumm Road 
Lenexa 66215 
Tel: (913) 888-8900 

MARYLAND 

Cramer/EW Baltimore 
7235 Standard Drive 
Hanover 21 076 
Tel: (301) 796-5790 
t Cramer/EW Washington 
16021 Industrial Drive 
Gaithersburg 20760 
Tel: (301)948-0110 
tHamilton/Avnet Electronics 
7235 Standard Drive 
Hanover 21076 
Tel: (301) 796-5000 

MASSACHUSETTS 

fCramer Electronics Inc. 
85 Wells Avenue 
Newton 02159 
Tel: (617) 969-7700 
fHamilton/Avnet Electronics 
100 E. Commerce Way 
Woburn 01801 
Tel: (617) 273-2120 

MICHIGAN 

Sheridan Sales Co. 
24543 Indoplex Drive 
Farmington Hills 48024 
Tel: (313) 477-3800 
i Pioneer/Michigan 
13485 Stamford 
Livonia 48150 
Tel: (313) 729-8500 
tHamilton/Avnet Electronics 
12870 Farmington Road 
Livonia 48150 
Tel: (313) 522-4700 
TWX: 810-242-8775 

MINNESOTA 

tlndustrial Components 

5280 West 74th Street 

Minneapolis 55435 

Tel: (612) 831-2666 

Cramer/Bonn 

7275 Bush Lake Road 

Edina 55435 

Tel: (612) 835-7811 

tHamilton/Avnet Electronics 

7683 Washington Avenue So. 

Edina 55435 

Tel: (612) 941-3801 

MISSOURI 

tHamilton/Avnet Electronics 
384 Brookes Lane 
Hazelwood 63042 
Tel: (314) 731-1144 

NEW JERSEY 

Cramer/Pennsylvania, Inc. 
12 Springdale Road 
Cherry Hill Industrial Center 
Cherry Hill 08003 
Tel: (609) 424-5993 
TWX: 710-896-0908 
Components Plus 
310 Railroad Avenue 
Hackensack 07601 
Tel: (201)487-0565 



NEW JERSEY (cont.) 

(Hamilton/Avnet Electronics 

218 Little Falls Road 

Cedar Grove 07009 

Tel: (201) 239-0800 

TWX: 710-994-5787 

Cramer/New Jersey 

No. 1 Barrett Avenue 

Moonachie 07074 

Tel: (201) 935-5600 

tHamilton/Avnet Electronics 

113 Gaither Drive 

East Gate Industrial Park 

Mt. Laurel O8057 

Tel: (609) 234-2133 

TWX: 710-897-1405 



NEW MEXICO 

Hamilton/Avnet Electronics 
2450 Baylor Drive, S.E. 
Albuquerque 87119 
Tel: (505) 765-1500 
Cramer/New Mexico 
137 Vermont, N.E. 
Albuquerque 87108 
Tel: (505) 265-5767 

NEW YORK 

Cramer/Rochester 

3000 Winton Road South 

Rochester 14623 

Tel; (716) 275-0300 

Components Plus 

40 Oser Avenue 

Hauppauge 1 1787 

Tel: (516) 231-9200 

tHamilton/Avnet Electronics 

167 Clay Road 

Rochester 14623 

Tel: (716) 442-7820 

f Cramer/Syracuse 

6716 Joy Road 

East Syracuse 13057 

Tel: (315) 437-6671 

tHamilton/Avnet Electronics 

6500 Joy Road 

E. Syracuse 13057 

Tel: (315) 437-2642 

tCramer/Long Island 

29 Oser Avenue 

Hauppauge, L.l. 1 1787 

Tel: (516) 231-5600 

TWX: 510-227-9863 

tHamilton/Avnet Electronics 

70 State Street 

Westbury, L.l. 11590 

Tel. (516) 333-5800 

TWX: 510-222-8237 



NORTH CAROLINA 

Cramer Electronics 
938 Burke Street 
Winston-Salem 27102 
Tel: (919) 725-8711 

OHIO 

tHamilton/Avnet Electronics 

118 Westpark Road 

Dayton 45459 

Tel: (513) 433-0610 

TWX: 810-450-2531 

tPioneer/Dayton 

1900 Troy Street 

Dayton 45404 

Tel. (513) 236-9900 

tSheridan Sales Co. 

10 Knollcrest Drive 

Cincinnati 45222 

Tel: (513) 761-5432 

TWX: 810-461-2670 

t Pioneer/Cleveland 

4800 E. 131st Street 

Cleveland 44105 

Tel: (216) 587-3600 

fHamilton/Avnet Electronics 

761 Beta Drive 

Cleveland 44143 

Tel: (216) 461-1400 

Sheridan Sales Co. 

23224 Commerce Park Road 

Beachwood 44122 

Tel: (216) 831-0130 

Sheridan Sales Co. 

Shiloh Building, Suite 250 

5045 North Main Street 

Dayton 45405 

Tel: (513) 277-8911 



OKLAHOMA 

Components Specialties, Inc. 

7920 E. 40th Street 

Tulsa 74145 

Tel: (918) 664-2820 



OREGON 

Almac/Stroum Electronics 
4475 S.W. Scholls Ferry Rd. 
Portland 97225 
Tel: (503) 292-3534 

PENNSYLVANIA 

Sheridan Sales Co. 

1717 Penn Avenue, Suite 5009 

Pittsburgh 15221 

Tel: (412) 244-1640 

Pioneer/Pittsburgh 

560 Alpha Drive 

Pittsburgh 15238 

Tel: (412) 782-2300 

TEXAS 

Cramer Electronics 

13740 Midway Road 

Dallas 75240 

Tel: (214) 661-9300 

tHamilton/Avnet Electronics 

4445 Sigma Road 

Dallas 75240 

Tel: (214) 661-8661 

tHamilton/Avnet Electronics 

1216 W.Clay 

Houston 77019 

Tel: (713) 526-4661 

Component Specialties, Inc. 

10907 Shady Trail, Suite 101 

Dallas 75220 

Tel: (214) 357-4576 

tComponent Specialties, Inc. 

7313 Ashcroft Street 

Houston 77036 

Tel: (713) 771-7237 

UTAH 

Cramer/Utah 
391 W. 2500 South 
Salt Lake City 84115 
Tel: (801) 487-4131 
Hamilton/Avnet Electronics 
647 W. Billinis Road 
Salt Lake City 84119 
Tel: (801) 262-8451 

WASHINGTON 

tHamilton/Avnet Electronics 

13407 NorthrupWay 

Bellevue 98005 

Tel: (206) 746-8750 

f Almac/Stroum Electronics 

5811 Sixth Ave. South 

Seattle 98108 

Tel: (206) 763-2300 

Cramer/Seattle 

1059 Andover Park East 

Tukwila 98188 

Tel: (206) 575-0907 

CANADA 

ALBERTA 

L. A. Varah Ltd. 
4742 14th Street N.E. 
Calgary T2E 6LT 
Tel: (403) 276-8818 
Telex: 13 825 89 77 

BRITISH COLUMBIA 

tL.A. Varah Ltd. 
2077 Alberta Street 
Vancouver V5Y 1C4 
Tel: (604) 873-3211 
TWX: 610-929-1068 
Telex: 04 53167 

ONTARIO 

Cramer/Canada 

920 Alness Avenue, Unit No. 9 

Downsview 

Toronto 392 M3J 2H7 

Tel: (416) 661-9222 

TWX: 610-492-6210 

Hamilton/Avnet Electronics 

6291-16 Dorman Road 

Mississauga L4V 1H2 

Tel. (416) 677-7432 

TWX: 610-492-8867 

Hamilton/Avnet Electronics 

1735 Courtwood Cresc. 

Ottawa K2C 2B4 

Tel: (613) 226-1700 

TWX. 610 562-1906 

OUEBEC 

fHamilton/Avnet Electronics 

2670 Paulus 

St. Laurent H4S 1G2 

Tel: (514) 331-6443 

TWX: 610-421-3731 

MANITOBA 

LA. Varah Ltd. 
153 Corbett Drive 
Winnipeg R2Y 1V4 
Tel: (204) 889-9607 

tMDS Centers 
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